alternative captcha methods

前端 未结 4 1915
小蘑菇
小蘑菇 2021-01-12 05:43

I\'m looking for inspiration here. I need to employ some sort of human verification for my website, but the most common method these days (asking users to type the letters &

4条回答
  •  花落未央
    2021-01-12 06:09

    Try using an ajax based submission process that's triggered by clicking a normal button (not a submit button), it's really easy with jQuery.

    As far as I can tell, spambots don't have javascript.

    If you're worried about users without javascript enabled, I think it's perfectly ok to have them unable to submit the form. If they can't trust you to enable javascript on your site, it's not your fault that they can't use the website to its fullest extent.

    EDIT:

    Also see: Practical non-image based CAPTCHA approaches?

    The problem though, if someone is targeting your site purposely, this kind of technique won't work.

    EDIT2:

    I can't provide a link to a real life example, but I blogged about it with a bit more details, so here's some sample code:

    function submit_form()
    {
        jQuery.ajax({
          "type": "POST", // or GET
          "url": 'action_url', // The url you wish to send the data to, the url you'd put in the "action" attribute on the form tag
          "data": jQuery("form#the-form").serialize(), // The data you'll send. You need to get the form somehow. Easiest way is to give it an id.
          "dataType": "json", // Only put this if the server sends the response in json format
          "success": function(data, textStatus) // server responded with http status 200
            {
                // This is the happy case: server response has arrived
            },
          "error": function(req, textStatus, errorThrown) // maybe HTTP 404 or HTTP 500
            {
                // something went wrong, the response didn't go through or the response didn't come. Handle the situation: let the user know, or something.
            },
          "complete": function(req, textStatus) // This one always gets called anyway
            {
                // cleanup after yourself
            }   // XXX careful: if you put a comma here, IE6 will fail
          });
    }
    

提交回复
热议问题