URL 다시 쓰기 메커니즘: URL 주소가 고유한지 확인하기 위해 서버에 전달되는 매개변수는 매번 다를 수 있습니다. 여기서, 인증코드 변경 기능을 구현하면, 파라미터 목록의 값이 새로고침으로 변경됩니다. 자세한 코드는 이 글을 참조하세요
URL 재작성 메커니즘: URL 주소가 고유한지 확인하기 위해 서버에 전달되는 매개변수가 매번 다를 수 있습니다.
데이터 요청의 헤더 정보를 분석할 수 있습니다. 헤더 정보에는 http 프로토콜, IP 주소, 포트 번호, 프로젝트 이름, 요청 매개변수 목록이 포함됩니다. 액세스하려는 리소스가 변경되지 않는 경우에만 변경할 수 있습니다. 매개변수 연결 목록.
여기서 인증코드 변경 기능을 구현할 때 매개변수 목록의 값을 이용해 새로고침을 하게 됩니다.
상세 코드 구현:
<%@page import="javax.imageio.ImageIO"%> <%@page import="java.awt.Font"%> <%@page import="java.awt.Color"%> <%@page import="java.awt.Graphics"%> <%@page import="java.awt.image.BufferedImage"%> <%@ page contentType="image/jpeg" language="java" import="java.util.*" pageEncoding="UTF-8"%> <% int w=100; int h=30; BufferedImage bi=new BufferedImage(w,h,BufferedImage.TYPE_INT_RGB); Graphics g=bi.getGraphics(); Color c=g.getColor(); Font f=g.getFont(); Random r=new Random(); Color bg=new Color(150+r.nextInt(100),150+r.nextInt(100),150+r.nextInt(100)); g.setColor(bg); g.fillRect(0, 0, w, h); String code=""; for(int i=1;i<=4;i++){ int num=r.nextInt(10); code=code+num; Color num_c=new Color(r.nextInt(150),r.nextInt(150),r.nextInt(150)); g.setColor(num_c); g.drawString(String.valueOf(num), 20*i, h/2); } request.getSession().setAttribute("code", code); //清空缓存 response.setHeader("pragma", "bo-cache"); response.setHeader("cache-control", "bo-cache"); response.addDateHeader("expires", 0); ImageIO.write(bi, "jpeg", response.getOutputStream()); out.close(); %>
로그인 페이지 추가:
<%@ page contentType="text/html; charset=utf-8" language="java" import="java.util.*" pageEncoding="UTF-8"%> <%String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>" rel="external nofollow" > <title>My JSP 'login.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css" rel="external nofollow" > --> <script type="text/javascript"> function changeimage(){ var d=new Date();//生成时间戳, document.getElementById("img").src="image.jsp?t="+d;//由变化的时间使参数连表发生变化,url重写 } </script> </head> <body> <font color="red">${requestScope.msg }</font> <form action="loginServlet" method="post"> name:<input type="text" name="uname"><br> pwd:<input type="pwd" name="upwd"><br> code:<input type="text" name="code" size="5"><img id="img" alt="" src="image.jsp "><a onclick="changeimage()">换一张</a><br> <input type="submit" > </form> </body> </html>
시간 변경을 사용하여 매번 타임스탬프를 생성하고 요청된 URL에 매개변수를 전달하여 URL 새로 고침 목적을 달성합니다. 한 장의 사진을 바꾸는 기능입니다.
위 내용은 인증 코드 변환을 구현하기 위한 URL 재작성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!