基于JSP+SERVLET的新闻发布系统(一)
本系统使用的是基于JSP+SERVLET+TOMCAT6
数据库使用的是MYSQL
IDE是MYECLIPSE8.5,页面编辑使用的是百度的ueditor,比较适合咱国人
采用MVC模式,使用的关键技术,通用的分页技术,一些项目开发的小技巧,如批量删除,,,本文章适合刚学习JSP+SERVLET,但没有实战经验的童鞋。欢迎交流学习。
1,第一个模块是登陆处理。
关键代码如下:
<form action="${pageContext.request.contextPath }/user?method=login" onsubmit="return submitCheck();"
method="post" id="loginForm">
<fieldset>
<legend>用户登录</legend>
用户名:<input type="text" id="userName" name="userName" /><br /> <br/>
密 码:<input
type="password" id="password" name="password" /><br />
<input type="submit" value="登录" /> <br />
<span id="msg" style="color: red">${msg}</span>
</fieldset>
</form>
<span id="msg" style="color: red">${msg}</span>该句代码用于反馈后台的校验信息,如用户名与密码不匹配等。
接受参数使用的是一个小工具类
User user = (User) CopyPropertyUtil.copyPropertiesFromRequest(request,
User.class);
该方法会自动的把接受到的FORM表单的值赋值到User类中,可以节省很多重复性的代码。
SERVLET的关键代码如下:
if ("login".equals(method)) {
user = userService.checkUser(user);
if (StringUtils.isNotBlank(user.getUserName())) {
HttpSession session = request.getSession();
session.setAttribute("user", user);
request.getRequestDispatcher("index.html").forward(request,
response);
} else {
request.setAttribute("msg", "用户名或密码错误");
request.getRequestDispatcher("index.jsp").forward(request,
response);
}
}
request.setAttribute("msg", "用户名或密码错误");用于反馈错误信息到登陆页面。
2,登陆成功则是菜单栏,由于时间有限,没有做菜单的动态生成。
在LEFT.JSP中,查询的链接统一用user?method=query method的query ,在该方法中写了通用的分页,并且是加上查询结果的分页。
if ("query".equals(method)) {
queryAll(request, response, user);
}
public void queryAll(HttpServletRequest request,
HttpServletResponse response, User user) throws ServletException,
IOException {
int currPage;
try {
currPage = Integer.valueOf(request.getParameter("currPage"));
} catch (Exception e) {
currPage = 1;
}
Page page = new Page();
List<User> list = userService.findAll(user);
page.setTotalPage(list.size());
page.toPage(currPage);
list = userService.findAll(user, page);
request.setAttribute("user", user);
request.setAttribute("page", page);
request.setAttribute("userList", list);
request.getRequestDispatcher("/user/userList.jsp").forward(request,
response);
}
request.setAttribute("page", page); 该对象用于保存分页的信息.
List<User> list = userService.findAll(user); 该方法是查询出需要显示的集合数据。
DAO代码如下:
public List findAll(User user){
Connection conn = DBUtil.getConnection();
ArrayList list= new ArrayList();
StringBuilder sb = new StringBuilder();
sb.append("select * from user where 1 = 1 ");
if(StringUtils.isNotBlank(user.getUserName())){
sb.append(" and userName like '%"+user.getUserName()+"%'");
}if(StringUtils.isNotBlank(user.getRole())){
sb.append(" and role like '%"+user.getRole()+"%'");
}
ResultSet rs = DBUtil.querySQL(sb.toString(), null,conn);
try{
while(rs.next()){
User temp = new User();
temp.setUserId(rs.getInt(1));
temp.setUserName(rs.getString(2));
temp.setPassword(rs.getString(3));
temp.setRole(rs.getString(4));
list.add(temp);
}
}catch(Exception e){
e.printStackTrace();
}finally{
DBUtil.closeAll(rs, null, conn);
}
return list;
}
效果如下:
接下来将重点讲解基于查询结果的分页技术。
由于查询条件的是通过FORM提交,但是在点击“下一页”的时候仍需保存之前的查询条件,可采用如下方式解决。
<a href="${pageContext.request.contextPath}/user?currPage=${page.currPage+1 }&method=queryPage&userName=${user.userName}&role=${user.role}">下一页</a>
将查询条件放在链接中,这样就能一直保存查询的条件,查询出正确的结果。
但是由于通过表单提交跟链接的解码方式不一样,因此需另外处理。
解码如下:
if ("queryPage".equals(method)) {
String userName = null, role = null;
// 当查询条件是通过链接的时候,由于是中文,所以需要进行解码
if (StringUtils.isNotBlank(request.getParameter("userName")))
userName = new String(request.getParameter("userName")
.getBytes("ISO-8859-1"), "UTF-8");
if (StringUtils.isNotBlank(request.getParameter("role")))
role = new String(request.getParameter("role").getBytes(
"ISO-8859-1"), "UTF-8");
user.setUserName(userName);
user.setRole(role);
queryAll(request, response, user);
}
这样就能完美解决基于查询结果的分页了。
3‘SELECT动态获取数据
角色中的数据是动态加载的,可使用如下语句获得:
<select name="role" id=""role"" style="width: 100">
<option value="">请选择</option>
<%
Role role = new Role();
RoleService roleService = new RoleService();
List<Role> roleList = roleService.findAll(role);
if(roleList!=null&&roleList.size()>0){
for(int i=0;i<roleList.size();i++){
role=roleList.get(i);%>
<option value="<%=role.getRoleId() %>">
<%=role.getRoleName() %>
</option>
<%}
}%>
</select>
4,删除使用的是批量删除,其实批量删除很简单,如果说难的话就是JS不会用,
我们可以通过CHECKBOX获取所有选中的ID,然后拼接成字符串,提交到后台,可拼接成1,2,3,5
后台可以使用如下方法去拆分
String str = request.getParameter("str");
str = str.substring(0, str.length() - 1);
String box[] = str.split(",");
for (String temp : box) {
int userId = Integer.valueOf(temp);
user.setUserId(userId);
userService.delUser(user);
}
先上传这么多,晚点更新其他模块。
基于JSP+SERVLET的新闻发布系统(一)的更多相关文章
- 基于JSP+SERVLET的新闻发布系统(三)
拖了这么久..今天把栏目管理还有新闻管理模块的也挂出来.. 栏目管理跟用户管理一样. 这里重点讲解新闻管理. 效果图如上: 1,可选择栏目类别,且栏目类别是动态生成的. 默认生成的文章是未审核状态的. ...
- 基于JSP+SERVLET的新闻发布系统(二)
接下来讲解的是通过AJAX验证用户名是否已经添加 用户名: <input type="text" name="userName" id="use ...
- 基于JSP+Servlet开发手机销售购物商城系统(前台+后台)源码
基于JSP+Servlet开发手机销售购物商城系统(前台+后台) 开发环境: Windows操作系统 开发工具:Eclipse/MyEclipse+Jdk+Tomcat+MySQL数据库 运行效果图: ...
- DRP PK 牛腩新闻发布系统
一.JSP与ASP (1)Web服务器的支持:大多数通用的Web服务器如:Apache.Netscape和Microsoft IIS都支持JSP页面,只有微软本身的Microsoft IIS和Pers ...
- News新闻发布系统
News新闻发布系统分页的实现 1.首先我们要在NewsDAO中创建一个方法,返回List<NewsEntity>集合,其中pageIndex表示当前页,pageSize表 ...
- 基于JSP的学术交流论坛系统的设计与实现
版权声明:本文为[博主](https://zhangkn.github.io)原创文章.未经博主同意不得转载. https://creativecommons.org/licenses/by-nc-s ...
- 安卓项目-利用Sqlite数据库,开发新闻发布系统
本教程致力于程序员可以快速的学习安卓移动端手机开发. 适合于已经习得一种编程语言的同仁. 更多志同道合,想要学习更多编程技术的大神们. 小弟不才,麻烦关注一下我的今日头条号-做全栈攻城狮. 本文章是基 ...
- 基于jsp+servlet图书管理系统之后台万能模板
前奏: 刚开始接触博客园写博客,就是写写平时学的基础知识,慢慢发现大神写的博客思路很清晰,知识很丰富,非常又价值,反思自己写的,顿时感觉非常low,有相当长一段时间没有分享自己的知识.于是静下心来钻研 ...
- 【NodeJS 学习笔记04】新闻发布系统
前言 昨天,我们跟着这位大哥的博客(https://github.com/nswbmw/N-blog/wiki/_pages)进行了nodeJS初步的学习,最后也能将数据插入数据库了 但是一味的跟着别 ...
随机推荐
- matlab实现协同过滤之pdist、squareform
实现协同过滤算法的第一步是:计算用户或项目之间的相似度.接下来介绍pdist和squareform 用法: D = pdist(X) D = pdist(X,distance) D = pdist ...
- Qt布局与分割器QSplitter
Qt的布局方式主要有四种: QGridLayout 栅格布局 QFormLayout 表格布局 QHBoxLayout 水平布局 QVBoxLayout ...
- PROPAGATION_REQUIRED
PROPAGATION_REQUIRED (2009-05-13 13:26:52) 转载▼ 事务传播行为种类 Spring在TransactionDefinition接口中规定了7种类型的事务传 ...
- IT第六天 - eclipse快捷操作、万年历项目的编写、菱形的打印输出、代码简化
IT第六天 上午 小项目 1.程序提前结束的退出标志 2.登录用户的模拟,给出适当的提示信息 3.根据要求,寻找规律,然后编写程序 Eclipse的使用 1.快捷键的使用 下午 中小项目 1.九九乘法 ...
- MSSQLServer的备份与还原
最近用到了mssql2000的数据备份还原到2008上, 在备份2000时,一定注意要备份成一个文件,就是目标那里只添加一个就好,(否则待会还原数据库时要添加这两个文件,要不就报“备份了几个簇,只提供 ...
- iOS UIWebView 之 UIProgressView
之前做等待跳转都是用UIActivityIndicatorView ,后来做webView 加载页面的时候,发现了一个特别好用又超级炫酷的加载提示NJKWebViewProgress,作者巧妙的通过计 ...
- Android访问网络(可以正常使用)
以下是MainActiviy.java,有必要的注释,里面用到了handler,以及线程,workThread如何更新mainThread才能够更新的内容. package com.wyl.httpt ...
- Altera FPGA中的pin简介
第一步要看的肯定是pin planner ,这个是黑金四代EP4CE15F17C8的视图 先就是发现他们pin有不同的颜色区域,分别对应不同的bank,应该是有的设计里面要求pin在同一个bank吧( ...
- nice Validator参考
快速上手 例1. DOM传参 1. 要验证一个表单,只需要给字段绑定规则“data-rule”就可以了2. 字段可以有多条规则,规则之间用分号(;)分隔3. js初始化不是必要的,只要是字段并且带有“ ...
- HDU 4739 求正方形个数
九野的博客,转载请注明出处:http://blog.csdn.net/acmmmm/article/details/11711707 求所有可能围成的正方形,借个代码 #include <que ...