关于用户禁用Cookie的解决办法和Session的图片验证码应用

  当用户通过客户端浏览页面初始化了Session之后(如:添加购物车,用户登陆等),服务器会将这些session数据保存在:Windows保存在C:\WINDOWS\Temp的目录下,Linux则是保存在/tmp 或 /var/lib/php/session目录下,之后给客户端返回一个Set-Cookie的参数(该参数表示在服务器端创建的Session_ID,可在http协议中看到),当该服务器的其他web端需要Session数据时则客户端会向服务器发送这个Session_ID,服务器就可以从Session文件中查找并调用;

  如果当用户在客户端禁用Cookie之后,如何实现Session共享多个页面;URL重写则可以解决;

  可以使用PHP提供的一个常量SID;这个常量可以获取到当前客户端在服务器所创建的Session文件的session_ID(文件名);使用方法;

    第一种方法,在超链接,action,header可以直接拼接将ID传递给需要session数据的页面,同时需要在页面写判定当读取到SID存在时则使用当前SID,若无则在服务器重新session_start()一个新的Session文件;

    if(isset($_GET[ ‘ SID ‘ ])){

      session_id($GET_[ ‘ sid ‘ ];

    }

    session_start();

    第二种方法,可以在php.ini文件中找到session.use_trans_sid = 1 ;来指定是否启用透明SID,启用之后在超链接,action,header,会自动将SID传递,设置完成重启apache生效;

  使用Session验证码技术;

    要想使用Session的验证码技术,首先要启用PHP自带的绘图库,应该在php.ini文件目录下启用 extension=php_gd2.dll ,重启apache生效;

    首先在需要验证码的界面加上输入文本框和图片,图片会请求checkCode页面随机生成一个验证码,并且写上点击随机更换的代码;

    

    其次在checkCode页面生成4个随机数并组合成字符串,通过PHP的绘图技术随机添加背景色干扰线以及随机生成的字符串,最后生成图片返回给客户端页面,并将生成的四位随机数保存在Session中;

    

  当输入验证码进行验证时,在验证页面写一个判断语句,判断文本框输入的值是否不等于$_Session[ " mycheckCode " ];

  这只是一个简单的案例,如今的验证码技术也是各有千秋,破解验证码的技术也平分秋色,验证码也就是阻挠一小拨别有用心的人;

  

原文地址:https://www.cnblogs.com/privateWa/p/8835484.html

时间: 2024-10-07 17:50:19

关于用户禁用Cookie的解决办法和Session的图片验证码应用的相关文章

【Android】eclipse打不开的解决办法和“Jar mismatch! Fix your dependencies”的解决

JDK1.7能用,cmd下输入java,javac,java -version,javaw配置和环境都没问题的话,有可能是工作空间的问题,就是一般在D盘下的workspace..那个文件夹,删除了,再打开eclipse. 换了工作空间之后,有的项目重新导入有时会出现"Jar mismatch! Fix your dependencies"错误.,这时就需要选择要改的项目的首选项,然后删除Android选项下的带X的Library,这是因为两个项目的jar包(android-suppor

PHP--浏览器禁用cookie后,怎么使用session

sessionid是存储在cookie中的,解决方案如下: Session URL重写,保证在客户端禁用或不支持COOKIE时,仍然可以使用Session session机制.session机制是一种服务器端的机制,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存信息. 当 程序需要为某个客户端的请求创建一个session时,服务器首先检查这个客户端的请求里是否已包含了一个session标识(称为session id),如果已包含则说明以前已经为此客户端创建过session,服务器

SQL Server 2008 R2评估期已过的解决办法和sqlserver 服务器打不开问题

运行regedit  找到HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\100\ConfigurationState  CommonFiles数值数据修改为3 所有程序 Microsoft SQL Server 2008 R2—— 配置工具——SQL Server 安装中心 再进入维护界面,选择版本升级 开发版: PTTFM-X467G-P7RH2-3Q6CG-4DMYB(一般是这个)企业版: JD8Y6-HQG69-P9H

用户禁止cookie,如何继续使用session?

可以使用url重写机制来解决这个问题 (1)什么是url重写?  在浏览器访问web服务器上的某个地址时,使用 服务器生成的地址(会在地址后面添加sessionId). (2)如何进行url重写?  //用来链接地址.表单提交地址  response.encodeURL(String url);  //用在重定向地址  response.encodeRedirectURL(String url);  比如:   response.sendRedirct(   response.encodeRed

Java Web 禁用Cookie对Session的影响

如果客户端禁用了Cookie,那么服务端就不能得到Session了.因为通过Session ID来确定当前会话对应的服务端Session,而Session ID通过Cookie来传递,所以禁用Cookie相当于失去了Session ID,也就得不到Session了. 禁用Cookie时使用Session即传递Session ID的实现方式如下: 1 PHP自动跨页传递 设置php.ini配置文件中的"session.use_trans_sid = 1",或者编译时启用"--e

浏览器禁用Cookie,基于Cookie的会话跟踪机制失效的解决办法

当浏览器禁用Cookies时,基于Cookie的会话跟踪机制就会失效,解决办法是利用URL重写机制跟踪用户会话. 在使用URL重写机制的时候需要注意,为了保证会话跟踪的正确性,所有的链接和重定向语句中的URL都需要调用encodeURL()或encodeRedirectURL()方法进行编码.另外,由于附加在URL中的SessionID是动态产生的,对于每一个用户都是不同的,所欲对于静态页面的相互跳转,URL重写机制就无能为力了,但是,我们也可以通过将静态页面转换为动态页面来解决这个问题. 在w

php在客户端禁用cookie时让session不失效的解决方法

cookie固然好,不过有些客户端浏览器会禁用cookie,这就会导致你所依赖cookies的程序会失效或出错,那么若真出现用户关闭cookies的情况,PHP应该如何再次使用session?方法还是有的. 1.设置php.ini的session.use_trans_sid = 1或者打开enable-trans-sid选项,让PHP自动跨页传递session id.2.手动通过URL传值.隐藏表单传递session id.3.用文件.数据库等形式保存session_id,在跨页过程中手动调用.

客户端禁用Cookie后session失效的问题

客户端禁用Cookie后session会失效,该如何解决? 解决方法:使用URL重写技术 URL重写:在原来的URL后面加上";jsessionid=123456789" 即:url--->url;JSESSIONID=123 注意: *For robust session tracking, all URLs emitted by a servlet should be run through this method. Otherwise, URL rewriting cann

PHP中禁用cookie后session的实现

一.问题叙述: 已经知道,session的实现是基于cookie的.是将session的id通过cookie在客户端和服务器端传递.然后在各个页面之间保持同一个session.但如果用户将客户端浏览器的cookie禁用了之后,应该如何实现session信息呢? 解决办法是:通过在URL后面附加session_id的信息来维持不同页面之间的session_id的传递. 1 //create_session.php 2 <?php 3 session_start(); 4 $_SESSION['na