javaweb里利用action进行表数据判断并跳到目的网页的过程

action

action是SSH里Struts2的方法。
框架先实例化 Action 对象,在第二次提交时,Action 会重新实例化,每一个 Action 对象都服务一个请求,这和 Servlet 的原理是不一样的——servlet是只在服务器启动时加载一次,所有用户共享。

提交表格内容到action

关于HTML语言中的form表单提交的方式

(1)所有的表单元素如果要进行页面提交需要使用form标签包裹。

(2)关于form标签上的属性作用

action 提交的地址
发送当前页面的数据到另外的页面去。

method 请求的方式
get请求 特点:参数会暴露在地址栏上,数据大小有限制,不安全,做一些查询的工作
post请求 特点:与get请求正好相反

提交过程:以< input type=“image”>为例

head里定义basePath:
basePath可以让java项目获取根路径,通过绝对路径引入这些图片文件。然后我们需要在jsp文件的开头写下面的代码。

<head>
		<base href="<%=request.getScheme()+"://"+request.getServerName()+":"
	+request.getServerPort()+request.getContextPath()+"/page/" %>">
    <title><s:text name="login"/></title>
	<link rel="stylesheet" type="text/css" href="css/login.css">
	<script type="text/javascript" src="js/js.js"></script>

</head>

body里写明提交目的地和提交方法:

< body>
< s:actionerror/>
< s:fielderror key="dataErr"></s:fielderror> 
< s:form action="dologin" method="post" validate="true"> //post方式提交到xml里的dologin里处理

< input type=“image”> 使图片按钮具有提交功能:
input本来就是表单form的元素,< input type=“image”>说明:
创建一个图像控件,该控件单击后将导致表单(from)立即被提交。

如果此标签放置在标签内就直接具有提交功能,如果不在标签内,则可以使用< input type=“image” onClick = “formName.submit()”>方式提交。

struts.xml里配置这些方法:

<struts>
<include file="org/dreamtang/struts-aptat_default.xml" />
	<!-- 所有与用户相关的Action -->
       <package name="user" namespace="/user" extends="aptat_default">
       
		<!-- 登录页面 -->
		<action name="login">
			<result>/page/login.jsp</result>
		</action>
		
		
		<!-- 处理登录的Action -->
		<action name="dologin" class="org.dreamtang.action.UserAction" method="LoginAction">
		   //将表格的数据传给org.dreamtang.action.UserAction里的LoginAction函数处理
			<result name="success" type="redirectAction">welcome</result>
			<result name="input" type="chain">login</result>
		   //若返回success,进入welcome的action里再处理
		   //若返回input,进入login的action里再处理
		</action>
		
	  </package>
</struts>    

参数:
method:
对应处理函数。
result:
对应处理函数的返回值。
type:
1.dispatcher: 默认值,服务器内部跳转(跳转到jsp等web组件)
2.redirect: 作客户端重定向(重定向到web组件);
3.chain: 作服务器内部跳转(跳转到其他Action);
4.redirectAction: 作客户端重定向(重定向到其他Action)

.java里写对应处理函数:

public User LoginService(User user)  throws Exception{
		System.out.println(user.getLogin());
		check=userDAO.search(user.getLogin());		
		if(check==null)
			throw new Exception("not");//该登录名不存在
		if(check.getPassword().equals(user.getPassword())&&check.getIdentify()<4)
			return check;//登录成功
		throw new Exception("error");//密码错误
}


public String LoginAction() {
		try {
			user = userService.LoginService(user);
		} catch (Exception e) {// 登录失败
			e.printStackTrace();
			errorMessage = "帐号或密码错误";
			return INPUT;
		}
		// 登录成功,记录用户信息到session
		request.getSession().setAttribute("user", user);
		File f = new File(basePath + ("file") + "/photo/" + user.getLogin()
				+ "/" + user.getLogin() + ".jpg");
		if (f.exists()) {
			user.setPhoto("../../file/photo/" + user.getLogin() + "/"
					+ user.getLogin() + ".jpg");
		} else {
			user.setPhoto("../images/ico02.gif");
		}
		return SUCCESS;
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaWeb中使用Servlet和DAO进行联查,您可以按照以下步骤进行操作: 1. 创建数据库连接: 在Servlet中创建数据库连接,可以使用JDBC或者连接池等方式。 2. 编写SQL语句: 使用JOIN关键字将三个进行联结查询,并编写相应的SQL语句。例如: ```sql SELECT * FROM table1 JOIN table2 ON table1.column = table2.column JOIN table3 ON table2.column = table3.column; ``` 请根据您的具体名和字段名进行修改。 3. 创建DAO层: 创建一个DAO类,负责执行数据库操作。在该类中,编写一个方法来执行SQL查询并返回结果集。 ```java public class YourDAO { public List<YourObject> queryData() { List<YourObject> resultList = new ArrayList<>(); // 创建数据库连接 // 执行SQL查询,并将结果集封装为YourObject对象,添加到resultList中 // 关闭数据库连接 return resultList; } } ``` 4. 在Servlet中调用DAO方法: 在Servlet中实例化DAO对象,调用其方法来执行SQL查询,并获取返回的结果集。 ```java public class YourServlet extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { YourDAO dao = new YourDAO(); List<YourObject> resultList = dao.queryData(); // 将结果集存储到request或session等作用域中,传递给JSP页面进行展示 // 转发到JSP页面进行展示 } } ``` 5. 在JSP页面中展示数据: 在JSP页面中通过EL达式和JSTL标签等方式,遍历结果集并展示数据。 ```jsp <c:forEach var="data" items="${resultList}"> <tr> <td>${data.column1}</td> <td>${data.column2}</td> <td>${data.column3}</td> <!-- 根据您的具体字段名进行修改 --> </tr> </c:forEach> ``` 请根据您的具体需求和数据结构进行相应的修改。 以上是一个简单的示例,希望对您有所帮助。如果有任何疑问,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值