Spring MVC开发--开发用户登录功能

http://blog.chinaunix.net/uid-26284395-id-3053407.html

1.Spring MVC开发的流程。

(1)编写输入表单页面。

(2)配置处理器映射和处理器。

(3)编写Form类。

(4)编写处理器类。

(5)配置JSP视图解析器。

(6)编写返回JSP页面

 

2  本例的开发过程包括  已经配置好了Spring环境

(1)新建登录页面login.jsp

(2)配置处理器映射与处理器

(3)新建登录表单类com.demo.spring.forms.LoginForm.java

(4)新建登录处理器com.demo.spring.actions.LoginAction.java

(5)新建欢迎页面welcome.java

 

3  具体步骤说明

(1)新建登录页面login.jsp

添加两个表单项 用户名和密码 并需要提供一个登录按钮和一个引入到注册页面register.do的链接 使用参数method来决定使用哪一个请求注册管理器的函数入口

 

  1. <form name="form1" action="login.do" method="post">
  2. <table width="300" border="1">
  3.     <tr>
  4.         <td colspan="2">登录窗口</td>
  5.     </tr>
  6.     <tr>
  7.             <td>用户名td>
  8.             <td><input type="text" name="username" size="10"></td>
  9.     </tr>
  10.     <tr>
  11.             <td>密码</td>
  12.             <td><input type="password" name="password" size="10"></td>
  13.     </tr>
  14.     <tr>
  15.         <td colspan="2"><input type="submit" name="submit"
  16.             value="登录"> <a
  17.             href="register.do?method=init">注册新用户</a></td>
  18.     </tr>
  19. </table>
  20. </form>

 

(2)配置处理器映射与处理器

登录页面login.jsp的<form>提交地址为login.do   因此在applicationContest.xml中需要添加处理器映射

 

  1. <bean id="loginMapping"
  2.         class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
  3.         <property name="mappings">
  4.             <props>
  5.                 <prop key="/login.do">loginAction</prop>
  6.             </props>
  7.         </property>
  8.     </bean>

 

改映射指向/login.do   并交由loginAction处理器进行处理 因此接下来 我们添加处理器配置如下

 

  1. <!---定义Action-->
  2.     <bean id="loginAction"
  3.         class="com.demo.spring.actions.LoginAction">
  4.         <property name="commandClass">
  5.             <value>com.demo.spring.forms.LoginForm</value>
  6.         </property>
  7.         <!-- 指定失败要返回的页面 -->
  8.         <property name="formView">
  9.             <value>login</value>
  10.         </property>
  11.         <!-- 指定成功要返回的页面 -->
  12.         <property name="successView">
  13.             <value>welcome</value>
  14.         </property>
  15.     </bean>

这里指定使用处理器类为 com.demo.spring.actions.LoginAction 并指定3个属性

comandClass属性 指定输入的表单类为com.demo.spring.forms.LoginForm

formView属性 指定失败要返回的页面login.jsp

successView属性 指定成功要返回的页面welcome.jsp

 

(3)新建登录表单类com.demo.spring.forms.LoginForm.java

这个类是一个最原始的JavaBean类 包含了与login.jsp页面中表单相对应的变量 为变量添加getter/setter函数

 

  1. package com.demo.spring.forms;

  2. public class LoginForm {

  3.     private String username;

  4.     private String password;

  5.     public String getPassword() {
  6.         return password;
  7.     }

  8.     public void setPassword(String password) {
  9.         this.password = password;
  10.     }

  11.     public String getUsername() {
  12.         return username;
  13.     }

  14.     public void setUsername(String username) {
  15.         this.username = username;
  16.     }
  17. }

 

(4)新建登录处理器com.demo.spring.actions.LoginAction.java

这个类继承自SimpleFormController 我们只需要实现该类的onSubmit()函数即可接受用户的请求

在这个函数中

首先通过强制类型装换 取得用户的表单对象loginForm

调用函数isValid()判断是否验证成功 如果登录陈宫 则在Session中保存用户登录的用户名 并调用父类的getSuccessView()取得返回的success.jsp视图 返回ModelAndView对象

如果登录失败 首先取得错误对象model 将loginForm保存在model中 然后返回一个ModelAndView对象 其中第一个参数为getFormView() 表示返回login.jsp页面 第二个参数为model 表示传递错误映射列表

新建一个函数isValid()来进行登录验证 处理的逻辑为如果用户名和密码均为admin 则表示登录成功 否则登录失败

 

  1. package com.demo.spring.actions;

  2. import java.util.Map;

  3. import javax.servlet.http.HttpServletRequest;
  4. import javax.servlet.http.HttpServletResponse;

  5. import org.springframework.validation.BindException;
  6. import org.springframework.web.servlet.ModelAndView;
  7. import org.springframework.web.servlet.mvc.SimpleFormController;

  8. import com.demo.spring.dao.UserDAO;
  9. import com.demo.spring.forms.LoginForm;
  10. import com.demo.spring.util.Constants;

  11. public class LoginAction extends SimpleFormController {
  12.     

  13.     protected ModelAndView onSubmit(HttpServletRequest request,
  14.             HttpServletResponse response, Object command, BindException errors)
  15.             throws Exception {
  16.         LoginForm loginForm = (LoginForm) command;
  17.         if (isValid(loginForm)) {
  18.             request.getSession().setAttribute(Constants.USERNAME_KEY, loginForm.getUsername());
  19.             return new ModelAndView(getSuccessView());
  20.         } else {
  21.             Map modle = errors.getModel();
  22.             modle.put("loginForm", loginForm);
  23.             return new ModelAndView(getFormView(), modle);
  24.         }
  25.     }

  26.     public boolean isValid(LoginForm loginForm) {
  27.         if (loginForm.getUsername().equals("admin")
  28.                 || loginForm.getPassword().equals("admin")) {
  29.             return true;
  30.         } else {
  31.             return false;
  32.         }
  33.     }
  34. }

在上面的onSubmit() 函数中 如果登陆成功 则保存一个变量在Session中 为了统一改保存的变量命名 我们新建了一个实体类com.demo.spring.util.Constants.java 定义USERNAME_KEY来表示保存的变量名为username 这样在访问该变量时 只需要与你用Constants.java类的USERNAME_KEY变量即可

 

  1. package com.demo.spring.util;

  2. public class Constants {
  3.     public final static String USERNAME_KEY = "username";

  4. }

 

 

(5)新建欢迎页面welcome.java

 

  1. <%@ taglib prefix="spring" uri="/spring"%>
  2. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
  3. <%String path = request.getContextPath();
  4.             String basePath = request.getScheme() + "://"
  5.                     + request.getServerName() + ":" + request.getServerPort()
  6.                     + path + "/";
  7. %>

  8. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  9. <html>
  10. <head>
  11. <base href="<%=basePath%>">

  12. <title><spring:message code="welcome.page.title" /></title>

  13. <meta http-equiv="pragma" content="no-cache">
  14. <meta http-equiv="cache-control" content="no-cache">
  15. <meta http-equiv="expires" content="0">
  16. <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  17. <meta http-equiv="description" content="This is my page">

  18. <!--
  19.     <link rel="stylesheet" type="text/css" href="styles.css">
  20.     -->
  21. </head>

  22. <body>
  23. <form name="form1" action="logout.do" method="post">
  24. <table width="200" border="1">
  25.     <tr>
  26.         <td colspan="2">登陆成功</td>
  27.     <tr>
  28.         <td>欢迎你</td>
  29.         <td><%=(String) session.getAttribute("username")%></td>
  30.     </tr>
  31.     <tr>
  32.         <td colspan="2"><input type="submit" name="submit"
  33.             value="退出"></td>
  34.     </tr>
  35. </table>
  36. </form>
  37. </body>
  38. </html>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`feign-spring-mvc-starter` 是一个 Feign 的扩展,它支持使用 Spring MVC 注解来定义和调用 REST 服务。使用 `feign-spring-mvc-starter`,你可以像使用 Spring MVC 控制器一样定义 Feign 客户端,从而更方便地进行 REST 服务的开发。 在使用 `feign-spring-mvc-starter` 之前,你需要先了解 Feign 和 Spring MVC 的基本概念和用法。 Feign 是一个声明式的 Web 服务客户端,它可以帮助你更方便地定义和调用 REST 服务。Feign 的基本使用方法是定义一个接口,用于描述 REST 服务的 API,然后使用 Feign 注解来声明这个接口。 Spring MVC 是一个基于 Java 的 Web 框架,它提供了一组注解和 API,用于处理 Web 请求和响应。 `feign-spring-mvc-starter` 将 Feign 和 Spring MVC 结合起来,使你可以使用 Spring MVC 注解来定义和调用 REST 服务。使用 `feign-spring-mvc-starter`,你可以更方便地使用 Feign 来调用 REST 服务。 以下是一个使用 `feign-spring-mvc-starter` 的示例: 1. 添加 Maven 依赖 在 pom.xml 文件中添加以下依赖项: ```xml <dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-spring-mvc</artifactId> <version>5.3.1</version> </dependency> ``` 2. 定义 Feign 接口 定义一个 Feign 接口,用于描述 REST 服务的 API。例如: ```java @FeignClient(name = "example-service") public interface ExampleClient { @GetMapping("/example") String getExample(); } ``` 在这个接口中,我们使用了 `@FeignClient` 注解来声明这个接口是一个 Feign 客户端,并指定了服务的名称。然后,我们定义了一个 `getExample()` 方法,用于调用 example-service 服务的 /example 路径。 3. 定义 Spring MVC 控制器 定义一个 Spring MVC 控制器,用于处理来自客户端的请求。例如: ```java @RestController public class ExampleController { private final ExampleClient exampleClient; public ExampleController(ExampleClient exampleClient) { this.exampleClient = exampleClient; } @GetMapping("/") public String index() { return exampleClient.getExample(); } } ``` 在这个控制器中,我们注入了 `ExampleClient`,并在 `index()` 方法中使用它来调用 example-service 服务的 /example 路径。 4. 运行应用程序 现在,你可以运行应用程序并访问 http://localhost:8080/ ,你应该会看到来自 example-service 服务的响应。 这就是一个使用 `feign-spring-mvc-starter` 的示例。使用 `feign-spring-mvc-starter`,你可以更方便地使用 Feign 来调用 REST 服务。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值