真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)

這篇文章主要為大家展示了“javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)”這篇文章吧。

創(chuàng)新互聯(lián)是專業(yè)的邕寧網(wǎng)站建設(shè)公司,邕寧接單;提供成都網(wǎng)站制作、成都網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行邕寧網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊,希望更多企業(yè)前來合作!

初始版

初始版是沒有加分頁的。因為沒怎么學(xué)過前端,界面很丑陋。主要技術(shù):JSP,JavaBean,servlet,JDBC主要頁面如下:

登錄頁面

javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)

主頁

javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)

添加學(xué)生

javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)

查看所有學(xué)生

javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)

查詢學(xué)生

javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)

工程目錄

javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)

數(shù)據(jù)庫

兩個表,user表和student表。為了使用DBUtils工具,一定要注意數(shù)據(jù)庫表的屬性的命名和JavaBean的get(),set() 方法的匹配。比如t_user表里的uname,在JavaBean中是:private String uname,getUname(),setUname()。

CREATE TABLE t_user(
 uid CHAR(32) PRIMARY KEY,
 uname VARCHAR(40) NOT NULL,
 upassword VARCHAR(40) NOT NULL
);
CREATE TABLE t_student(
 sid CHAR(32) PRIMARY KEY,
 sname VARCHAR(40) NOT NULL,
 gender VARCHAR(6) NOT NULL,
 birthday CHAR(10),
 tellphone VARCHAR(15) NOT NULL,
 email VARCHAR(40), 
 description VARCHAR(500)
);

小知識點

登錄

登錄時,用戶名或密碼輸入框是否為空由登錄頁面的js代碼判斷,二者都不為空時,通過用戶名信息查詢數(shù)據(jù)庫,如果找到用戶則成功登錄,否則要判斷是用戶名錯誤還是密碼錯誤。這個事務(wù)在Service層處理,DAO層只負(fù)責(zé)通過用戶名查找用戶。

UserService代碼:

public class UserService {
 private UserDao userDao = new UserDao();

 public User query(User form) throws Exception{
 User user = userDao.query(form);

 //沒找到用戶
 if(user == null){
  throw new Exception("用戶名不存在");
 }

 //找到用戶了,但密碼不匹配
 if(!form.getUpassword().equals(user.getUpassword())){
  throw new Exception("密碼錯誤");
 }

 return user;
 }
}

Filter過濾器

為了防止沒有登錄的用戶也能直接訪問其他頁面,需要寫一個過濾器。將登錄頁面之外的所有頁面單獨放在一個users文件夾下,當(dāng)用戶登錄成功時,將該用戶的信息保存到session的“sessionUser”屬性中,過濾器判斷這個屬性是否為空,如果是空說明用戶登錄不成功,不放行,直接轉(zhuǎn)到登錄頁面,非空則放行。過濾器的主要代碼:

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) 
  throws IOException, ServletException {
 //1.得到session
 //2.判斷session中是否有用戶,如果有,放行
 //3.否則轉(zhuǎn)到登錄頁面
 HttpServletRequest req = (HttpServletRequest)request;
 User user = (User)req.getSession().getAttribute("sessionUser");
 if(user != null){
  chain.doFilter(request, response);
 }else{
  HttpServletResponse resp = (HttpServletResponse)response;
  resp.sendRedirect(req.getContextPath() + "/index.jsp");
 } 
 }

多條件組合查詢

在高級搜索頁面,有四個選項可以選擇:學(xué)生姓名,性別,手機(jī)號,郵箱。四個條件可以任意排列組合。之前寫QT項目時也遇到過這個問題,當(dāng)時用的就是拼接SQL語句,但是沒想到用“where 1=1”,很費事。下面的代碼很經(jīng)典,并且用到了模糊查詢,使搜索更人性化。

public List query(Student s){
 try{
 StringBuilder sql = new StringBuilder("SELECT * FROM t_student WHERE 1=1");
 List params = new ArrayList();

 if(s.getSname() != null && !s.getSname().trim().isEmpty()){
  sql.append(" and sname like ?");
  params.add("%" + s.getSname() + "%");
 }

 if(s.getGender() != null && !s.getGender().trim().isEmpty()){
  sql.append(" and gender=?");
  params.add(s.getGender());
 }

 if(s.getTellphone() != null && !s.getTellphone().trim().isEmpty()){
  sql.append(" and tellphone like ?");
  params.add("%" + s.getTellphone() + "%");
 }

 if(s.getEmail() != null && !s.getEmail().trim().isEmpty()){
  sql.append(" and email like ?");
  params.add("%" + s.getEmail() + "%");
 }

 return qr.query(sql.toString(), 
  new BeanListHandler(Student.class),
  params.toArray());
 }catch (Exception e) {
 throw new RuntimeException(e);
 }
}

進(jìn)化版:分頁

將查詢出來的分頁顯示,更加美觀。分頁形如:第N頁/共M頁 首頁 上一頁 1 2 3 4 5 6 7 8 9 10 下一頁 尾頁。

分頁效果如下:

javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)

分頁需要的數(shù)據(jù):

當(dāng)前頁:pageCode
總頁數(shù):totalPage
總記錄數(shù):totalRecord
每頁記錄數(shù):pageSize
當(dāng)前頁數(shù)據(jù):beanList

PageBean

由于這些分頁數(shù)據(jù)總要在各層之間來回的傳遞!我們把這些分頁數(shù)據(jù)封裝到一個javabean中,它就叫分頁Bean,例如:PageBean。當(dāng)使用多條件查詢后,再點擊第2 頁時,第2頁上的超鏈接沒有查詢條件,會丟失查詢條件,所以我們需要在頁面上的所有鏈接都要保留查詢條件!我們要把條件以一個字符串的形式保存到PageBean的url中!
代碼如下:

public class PageBean {
 private Integer pageCode;//當(dāng)前頁碼
 private Integer pageSize;//每頁數(shù)據(jù)大小
 private Integer totalRecord;//總記錄
 private List beanList;//當(dāng)前頁的記錄,定義成泛型為了以后直接用
 private String url;//多條件組合查詢時url后的條件

 //返回總頁數(shù)
 public Integer getTotalPage(){
 int tp = totalRecord/pageSize;
 return totalRecord%pageSize==0 ? tp : tp+1;
 }
 ...//屬性的get,set方法
 ...
}

分頁在各層中的處理

jsp頁面:顯示顯示數(shù)據(jù)和“第N頁/共M頁 首頁 上一頁 1 2 3 4 5 6 7 8 9 10 下一頁 尾頁”;給servlet傳遞pageCode
servlet:創(chuàng)建PageBean對象,給PageBean所有的屬性賦值,然后給DAO層傳遞pageCode和pageSize;接受DAO返回的PageBean對象,保存到request域,返回給頁面
service:充當(dāng)中間商的角色,沒有事務(wù)需要處理
DAO:得到pageCode和pageSize,創(chuàng)建PageBean對象,查詢數(shù)據(jù)庫得到totalRecord和beanList,返回PageBean。

jsp頁面處理頁碼的代碼:

第${pb.pageCode }頁/共${pb.totalPage }頁  首頁  1 }"> 上一頁            <%-- 計算公式 --%>      <%--- 頭溢出 --%>            <%-- 尾溢出 --%>   pb.totalPage}">           <%-- 循環(huán)顯示頁碼列表 --%>       [${i }]       [${i }]      下一頁 尾頁

加完分頁之后的多條件組合查詢代碼

public PageBean query(Student s,int pc,int ps){
 try{
 PageBean pb = new PageBean();
 pb.setPageCode(pc);
 pb.setPageSize(ps);

 /*
  * 查詢出總記錄
  */
 StringBuilder numSql = new StringBuilder("SELECT COUNT(*) FROM t_student");
 StringBuilder whereSql = new StringBuilder(" WHERE 1=1");
 List params = new ArrayList();

 if(s.getSname() != null && !s.getSname().trim().isEmpty()){
  whereSql.append(" and sname like ?");
  params.add("%" + s.getSname() + "%");
 }

 if(s.getGender() != null && !s.getGender().trim().isEmpty()){
  whereSql.append(" and gender=?");
  params.add(s.getGender());
 }

 if(s.getTellphone() != null && !s.getTellphone().trim().isEmpty()){
  whereSql.append(" and tellphone like ?");
  params.add("%" + s.getTellphone() + "%");
 }

 if(s.getEmail() != null && !s.getEmail().trim().isEmpty()){
  whereSql.append(" and email like ?");
  params.add("%" + s.getEmail() + "%");
 }

 Number number = (Number)qr.query(numSql.append(whereSql).toString(), 
  new ScalarHandler(),params.toArray());
 int totalRecord = number.intValue();
 pb.setTotalRecord(totalRecord);

 /*
  * 得到beanList結(jié)果集
  */
 StringBuilder sql = new StringBuilder("SELECT * FROM t_student");
 StringBuilder limitSql = new StringBuilder(" limit ?,?");
 params.add((pc-1)*ps);
 params.add(ps);
 List students = qr.query(sql.append(whereSql).append(limitSql).toString(),
  new BeanListHandler(Student.class),params.toArray());
 pb.setBeanList(students);
 return pb;
 }catch (Exception e) {
 throw new RuntimeException(e);
 }
}

以上是“javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


文章標(biāo)題:javaWeb如何實現(xiàn)學(xué)生信息管理系統(tǒng)
網(wǎng)址分享:http://weahome.cn/article/pghcjs.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部