当前位置: 首页 > news >正文

简约网站欣赏图片展示模块网站做一个多少钱

简约网站欣赏,图片展示模块网站做一个多少钱,无法进入网站后台,wordpress产品列表插件Cookie和Session出于安全考虑,浏览器不让网页直接操作文件系统,而Cookie就是一个折中的方案,可以让网页暂存一些数据在本地,不能存复杂的对象,只能存字符串。Cookie是按照域名分类的,这个很好理解。如何理解…

Cookie和Session

出于安全考虑,浏览器不让网页直接操作文件系统,而Cookie就是一个折中的方案,可以让网页暂存一些数据在本地,不能存复杂的对象,只能存字符串。

Cookie是按照域名分类的,这个很好理解。

如何理解Cookie从服务器来,到服务器去

来源:服务器将想进行存储的信息,通过字符串键值对的方式放到HTTP响应的Set-Cookie中

终点:服务器。客户端发送HTTP请求都会带上之前存储的Cookie信息(在HTTP的Header的Cookie中),让服务器去分析之前干了啥。

如何理解Cookie是在浏览器中工作的,session是在服务器这边工作的

识别用户信息的方式:

  1. 服务器直接通过Set-Cookie的方式返回用户信息给浏览器, 浏览器直接保存

  1. 服务器保存用户信息, 然后通过键值对进行保存. 其中键是由服务器(根据用户信息??)自动生成的唯一字符串, 值就是用户的详细信息. 服务器可以只把键(唯一字符串)通过Set-Cookie返回给浏览器.

两者的区别就是后者有点像是加密了, 后者将用户信息加密为键.

后面这样的处理方式, 就是会话方式. 键值对称之为session(会话), 唯一的字符串就称之为sessionId.

假如之前已经认证过信息,则再次登录流程如:

  1. 浏览器已有sessionId, 发送请求时候将sessionId一同发送给服务器

  1. 服务器根据接收的sessionId在哈希表中查找用户信息, 假如拿到了用户身份信息, 就认证成功, 反之失败.

服务器中用于存储用户信息的哈希表

以sessionId为key, 用户信息为value

每一个服务器中都会有很多个webapp,一个webapp对应一个存储session的哈希表,每一个哈希表的内容都是sessionId + session对象,每一个session对象中又可以又很多个键值对,如图:

创建一个前端页面:

<body><form action="login" method="post"><input type="text" name="Username"><input type="password" name="Password"><input type="submit" value="Submit"></form>
</body>

效果如:

点击Submit提交post请求后,后端处理登录信息:

  1. 查看用户名和密码输入格式,为空为null都要求重新输入

  1. 查看用户名和密码是否正确,不正确要求重新输入

@WebServlet("/login")
public class LoginServlet  extends HttpServlet {@Overrideprotected  void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {String username = req.getParameter("Username");String password = req.getParameter("Password");if (username == null || username.equals("") ||  password == null || password.equals("")) {
//            信息有误,重定向到登录页面resp.sendRedirect("login.html");return;}//        用户名密码错误,重定向到登录页面if (!username.equals("Mattylyh")  && !password.equals("222")) {resp.getWriter().write("Login failed, check your info before try  again.");return;}//              登录信息正确,创建sessionHttpSession session = req.getSession(true);
//        将用户信息(键值对)写到session中session.setAttribute("username",  "Mattylyh");
//        页面重定向到index初始页面  参数是相对路径resp.sendRedirect("index");}
}

验证信息成功后,

@WebServlet("/index")
public class IndexServlet  extends HttpServlet {@Overrideprotected  void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//        index页面的作用就是将用户信息显示出来HttpSession session = req.getSession(false);if (session == null) {
//           登录失败就跳转登录页面resp.sendRedirect("login.html");return;}String username = session.getAttribute("Username");resp.setContentType("text/html; charset=utf8");resp.getWriter().write("当前用户:" + username);}
}

session和Cookie的协同作用主要是用来保持登录状态吧?

即第一次验证登录成功后,服务器给浏览器一个Set-Cookie,然后浏览器根据这个Set-Cookie的内容设置好Cookie。这个Set-Cookie和Cookie的内容都是一个JSESSIONID

有了这个JSESSIONID,之后每次访问服务器都会知道你是通过了登陆验证的,就不会需要你重复登录了。

但是这个管理会话的哈希表是在服务器内存中的,假如服务器重启了,那原理啊的哈希表也没了,就会需要重启会话。

改进成一个可看到访问次数(通过sessionId判断同一用户)的代码:

@WebServlet("/login")
public class LoginServlet  extends HttpServlet {@Overrideprotected  void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {String username = req.getParameter("username");String password = req.getParameter("password");if (username == null || username.equals("") ||  password == null || password.equals("")) {
//            信息有误,重定向到登录页面resp.sendRedirect("login.html");return;}if (!username.equals("Mattylyh")  || !password.equals("222")) {resp.getWriter().write("Login failed, check your info before try  again.");return;}HttpSession session = req.getSession(true);
//        将用户信息(键值对)写到session中session.setAttribute("username",  "Mattylyh");session.setAttribute("visitCount",  0);
//        页面重定向到index初始页面  参数是相对路径resp.sendRedirect("index");}
}

@WebServlet("/index")
public class IndexServlet  extends HttpServlet {@Overrideprotected  void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {resp.setContentType("text/html; charset=utf8");
//        index页面的作用就是将用户信息显示出来HttpSession session = req.getSession(false);if (session == null) {
//           登录失败就跳转登录页面resp.sendRedirect("login.html");return;}String username = String.valueOf(session.getAttribute("username"));Integer visitCount = (Integer) session.getAttribute("visitCount");visitCount += 1;session.setAttribute("visitCount",  visitCount);resp.getWriter().write("当前用户:" + username + " 访问次数:" + visitCount);}
}
http://www.yayakq.cn/news/63122/

相关文章:

  • 网站建设的背景社交平台网站建设预算
  • 浙江网站建设推广公司哪家权威企业中层管理人员培训课程
  • 大气物流公司网站源码信息流广告视频
  • 一个网站上线需要什么检察门户网站建设
  • 沈阳网站建设教案模板上海第五届世界进口博览会
  • 建网站的步骤和方法友情链接发布平台
  • 怎么在自己的网站加关键词网站设计语言
  • 建设银行网站信息补充百度网盘seo优化
  • 做餐饮如何加入外卖网站wordpress 购物 手机站
  • jsp网站开发实例pdf兰州营销型网站建设
  • 网站建设選宙斯王wordpress增强插件
  • 广州市建设监理协会网站家装设计公司起名
  • 营销型 网站开发许昌seo推广
  • 普通网站 手机网站wordpress的页面链接错乱
  • 网站别人帮做的要注意什么手续企业网站需要哪些功能
  • 规范网站建设网站如何调用微博
  • 织梦做的网站图片路径在哪里wordpress+好用插件
  • 手机特殊网站wordpress 企業網
  • 网站建设详细合同范本wordpress导入媒体无法显示
  • 专业的网站设计网络淘宝联盟网站怎么建设
  • 建站需要注意哪些阿里云服务器租赁
  • 学做蛋糕哪个网站好网站改版提交给百度
  • 网上有女的叫你建网站做软装的网站
  • 网站建设报告 商业价值什么网站赚的钱最多
  • 太原php网站开发外汇直播室都是网站做的
  • 网站快照营销策划的概念
  • 做网站要买服务器吗亲子乐园网站建设规划
  • 恩施网站定制网站系统升级维护需要多长时间
  • 昌平电子网站建设广州手机网站建设哪家好
  • 现在找个网站这么难的吗网站开发过程文档