session图片验证码,页面和请求是两个地址。android手机好用,aphone 失效。

Posted _Phoenix

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了session图片验证码,页面和请求是两个地址。android手机好用,aphone 失效。相关的知识,希望对你有一定的参考价值。

问题描述:之前在H5页面用session做了一个验证码。安卓手机好使。但是到苹果就不好使了(页面访问是一个域名地址,ajax请求是用另外的一个ip地址)。

   详细说明: 验证码请求后台图片正常显示,androidios都可以。但是输入验证码到后台进行与图片的验证码数字校验 时,android 可以正常校对,ios会产生一个新的session,所以获取不到信息。用IOS 微信 和外部QQ浏览器 都不好使;

              问:请求用的是域名还是ip? 

     答:ajax 里面是IP 

     注意:这时的两个web请求不是同一个域名。

       1、 验证码显示如: 

        

         2、 后台代码:

                       跨域设置:

                                

                              

                               

                               

 

       最后是如何解决的呢?

         因为请求和应用本身不是同一个web应用,加上safari机制导致两次ajax请求有两个session  ,不是同一个session,所以验证码取不到      

         解决方案一(好使):有一种简单的方式可以绕过去,在原页面(网页浏览器域名路径)的域名上加个子域名映射映射到(ajax请求的ip),然后 

    ajax请求使用这个映射的子域名访问。

              这里要注意:原来可能不好使的手机需要清理下缓存重新测试!

 

    不好使的方案:直接把现有的ip改成域名

    其他不建议的方案:这里的小条是请求的页面域名,欠条是ajax请求的ip地址路径

                           

        页面请求如下:

       

 

 

 

                                           

 

以上是关于session图片验证码,页面和请求是两个地址。android手机好用,aphone 失效。的主要内容,如果未能解决你的问题,请参考以下文章

从session实现机制分析模拟请求验证码的可行性(转)

Listener

第二百七十节,Tornado框架-生成验证码图片,以及验证码结合Session验证

java验证码-汉字验证码

验证码

python第一百一十八天---ajax--图片验证码 + Session