ext2.0+jsp+struts 实现带有验证码的登录流程

1、给出效果图。

  2、给出login.js代码。

Ext.onReady(function() {
			var loginForm = new Ext.form.FormPanel(
					{
						title : '用户登录',
						width : 220,
						height : 160,
						frame : true,
						labelWidth : 50,
						labelAlign : 'right',
						renderTo : 'content',
						items : [
								new Ext.form.TextField( {
									name : 'name',
									fieldLabel : '名称'
								}),
								new Ext.form.TextField( {
									name : 'password',
									fieldLabel : '密码',
									inputType : 'password'
								}),
								new Ext.form.TextField(
										{
											name : 'checkCode',
											fieldLabel : '验证码',
											maxLength : 4,
											cls:'checkCode'
										}) ],
						buttons : [ {
							text : '登录',
							pressed : false,
							handler : function() {
								login(loginForm);
							}
						}, {
							text : '重置',
							pressed : false,
							handler : function() {
								loginForm.getForm().reset();
							}
						} ]
					});
		});

function login(form) {
	Ext.Ajax.request( {
		url : rootPath + '/login.do',
		method : 'post',
		success : function(response) {
			var result = Ext.decode(response.responseText);
			if (result.result == "success") {
				location.href = rootPath + "/pages/home/home.jsp";
			} else {
				form.setTitle('用户登录('+result.errMsg+')');
				/*通过添加删除类实现刷新验证码的功能*/
				form.getForm().findField('checkCode').removeClass('checkCode');
				form.getForm().findField('checkCode').addClass('checkCode');
				form.getForm().reset();
			}
		},
		params : {
			name : form.getForm().findField('name').getValue(),
			password : form.getForm().findField('password').getValue(),
			checkCode: form.getForm().findField('checkCode').getValue()
		}
	});
}

3、给出css文件:checkCode.css

.checkCode {
	background: url("checkCode.jsp") no-repeat;
	background-position: right center;
	background-color: white;
}

4、给出生成验证码的jsp文件。

<%@ page language="java" import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*"   
     contentType="image/jpeg" pageEncoding="UTF-8"%>  
 
 
<%  //设置页面不缓存  
   response.setHeader("Pragma","No-cache");  
   response.setHeader("Cahce-Control","no-cache");  
   response.setDateHeader("Expires",0);  
   //在内存中创建图片  
   int width=60,height=20;  
   BufferedImage image=new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);  
   //获取图形上下文  
   Graphics g= image.getGraphics();  
   //生成随机类  
   Random random= new Random();  
   //设置背景颜色  
   g.setColor(new Color(160,200,100));  
   g.fillRect(0,0,width,height);  
   //设置字体  
   g.setFont(new Font("Times New Roman",Font.PLAIN,18));  
   //随机产生50条干扰线,使图形中的验证码不易被其他的程序探测到  
    g.setColor(new Color(160,200,200));  
   for(int i=0;i<50;i++)  
   {  
     int x=random.nextInt(width);  
     int y=random.nextInt(height);  
     int x1=random.nextInt(width);  
     int y1=random.nextInt(height);  
     g.drawLine(x,y,x+x1,y+y1);  
   }  
   //随机产生验证码(4位数字)  
   String sRand="";  
   for(int i=0;i<4;i++)  
   {  
     String rand=String.valueOf(random.nextInt(10));  
     sRand+=rand;  
     //将验证码显示到图象  
     g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));  
     g.drawString(rand,13*i+6,16);  
   }  
   session.setAttribute("checkCode",sRand);  //将产生的验证码存储到sesson中  
   g.dispose();  
   ImageIO.write(image,"JPEG",response.getOutputStream());  
   out.clear(); //***********  
   out=pageContext.pushBody();//**********  
 %> 
<!--page language="java" import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*">     contentType="image/jpeg" pageEncoding="GBK-->
<!-->   response.setHeader("Pragma","No-cache"); 
   response.setHeader("Cahce-Control","no-cache"); 
   response.setDateHeader("Expires",0); 
   //在内存中创建图片 
   int width=60,height=20; 
   BufferedImage image=new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB); 
   //获取图形上下文 
   Graphics g= image.getGraphics(); 
   //生成随机类 
   Random random= new Random(); 
   //设置背景颜色 
   g.setColor(new Color(160,200,100)); 
   g.fillRect(0,0,width,height); 
   //设置字体 
   g.setFont(new Font("宋体",Font.PLAIN,18)); 
   //随机产生100条干扰线,使图形中的验证码不易被其他的程序探测到 
    g.setColor(new Color(160,200,200)); 
   for(int i=0;i<100;i++)>   { 
     int x=random.nextInt(width); 
     int y=random.nextInt(height); 
     int x1=random.nextInt(width); 
     int y1=random.nextInt(height); 
     g.drawLine(x,y,x+x1,y+y1); 
   } 
   //随机产生验证码(4位数字) 
   String sRand=""; 
   for(int i=0;i<4;i++)>   { 
     String rand=String.valueOf(random.nextInt(10)); 
     sRand+=rand; 
     //将验证码显示到图象 
     g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110))); 
     g.drawString(rand,13*i+6,16); 
   } 
   session.setAttribute("checkCode",sRand); //将产生的验证码存储到sesson中 
   g.dispose(); 
   ImageIO.write(image,"JPEG",response.getOutputStream()); 
   out.clear(); //*********** 
   out=pageContext.pushBody();//********** 

5、给出Action:LoginAction.java

package com.happyou.action;

import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import net.sf.json.JSONObject;
import com.happyou.bean.Guest;
import com.happyou.dao.GuestDAO;

public class LoginAction extends Action {
	GuestDAO guestDao;

	public void setGuestDao(GuestDAO guestDao) {
		this.guestDao = guestDao;
	}

	public ActionForward execute(ActionMapping mapping, ActionForm form,
			HttpServletRequest request, HttpServletResponse response) {
		String name = request.getParameter("name");
		String password = request.getParameter("password");
		String checkCode = request.getParameter("checkCode");
		JSONObject result = new JSONObject();
		if (!checkCode.equals(request.getSession().getAttribute("checkCode"))) {
			result.put("result", "failure");
			result.put("errMsg", "验证码输入错误");
		} else {
			String[] queryCondition = { name, password };
			List<Guest> guest = guestDao
					.find(
							"from Guest as model where model.name= ? and model.password=?",
							queryCondition);
			if (!guest.isEmpty()) {
				request.getSession().setAttribute("guest", guest.get(0));
				result.put("result", "success");
			} else {
				result.put("result", "failure");
				result.put("errMsg", "用户名或者密码错误");
			}
		}
		try {
			response.getWriter().write(result.toString());
		} catch (Exception e) {
			e.printStackTrace();
		}
		return null;
	}
}

6、思路简介

         通过checkCode.css 中的类checkCode,设置验证码输入框的样式,指定cls为checkCode。在login.js中有方法:login,通过添加删除类来实现验证码的刷新功能。生成验证码的jsp文件是统一的套路,这里不再详细说明。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在SQLAlchemy中定义外键可以使用ForeignKey约束。下面是一个示例代码: ```python from sqlalchemy import create_engine, Column, Integer, String, ForeignKey from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.orm import relationship engine = create_engine('sqlite:///example.db', echo=True) Base = declarative_base() class User(Base): __tablename__ = 'users' id = Column(Integer, primary_key=True) name = Column(String) addresses = relationship("Address", back_populates="user") class Address(Base): __tablename__ = 'addresses' id = Column(Integer, primary_key=True) email_address = Column(String, nullable=False) user_id = Column(Integer, ForeignKey('users.id')) user = relationship("User", back_populates="addresses") Base.metadata.create_all(engine) ``` 在这个示例中,我们定义了两个表:User和Address。Address表中有一个外键user_id,它引用了User表中的id列。这个外键使用ForeignKey约束来定义。 在User表的定义中,我们使用了relationship属性来定义与Address表的关系。这个属性告诉SQLAlchemy,User表的每个实例都有一个addresses属性,它是一个包含所有与该用户相关的Address实例的列表。 当我们使用这些模型类时,例如: ```python from sqlalchemy.orm import sessionmaker Session = sessionmaker(bind=engine) session = Session() user = User(name='John Doe') address = Address(email_address='[email protected]', user=user) session.add(user) session.add(address) session.commit() user = session.query(User).filter_by(name='John Doe').one() print(user.addresses) ``` 我们可以看到,我们可以通过user.addresses属性访问与该用户相关的所有地址。这是通过relationship属性定义的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值