JavaWeb學(xué)習(xí)過程之MVC查詢模式詳解
一、首先先了解一下 什么是mvc?
MVC是Model-View-Controller的簡(jiǎn)稱,即模型-視圖-控制器。它是一種設(shè)計(jì)模式,它吧應(yīng)用程序分成三個(gè)核心模塊,模型,視圖,控制器。他們各自處理自己的任務(wù)。
模型:是應(yīng)用程序的主體部分,模型指的是業(yè)務(wù)模型。 一個(gè)模型可以為多個(gè)視圖提供數(shù)據(jù)。
視圖:是用戶看到的并與之交互的界面。 可以向用戶顯示相關(guān)的數(shù)據(jù),接受用戶的輸入,但是它不進(jìn)行任何實(shí)際的業(yè)務(wù)處理。
控制器:接受用戶的輸入并調(diào)用模型和視圖,完成用戶的需求。
流程: 客戶端發(fā)送請(qǐng)求到 服務(wù)器, 服務(wù)器 將請(qǐng)求發(fā)送給servlet ,servlet接收請(qǐng)求,根據(jù)請(qǐng)求的業(yè)務(wù)邏輯調(diào)用model層,然后在想servlet返回一個(gè)結(jié)果,根據(jù)結(jié)果 轉(zhuǎn)向(轉(zhuǎn)發(fā),重定向)一個(gè)頁面。
二、具體查詢
問題:點(diǎn)擊頁面的一個(gè)超鏈接,顯示數(shù)據(jù)庫里學(xué)生的信息

1.根目錄結(jié)構(gòu)

2.
創(chuàng)建一個(gè)學(xué)生類Student。
內(nèi)容屬性: 獲取get,set方法。
private String studentId; private String name; private String idCard; private String sex; private int age; private int grade;
2.創(chuàng)建一個(gè)StudentDao類 用于獲取數(shù)據(jù)庫信息 返回學(xué)生鏈表
內(nèi)容:其中有我自己找的一個(gè)工具類
public class StudentDao {
public List<Student> getAll(){
List<Student> students=new ArrayList<Student>();
ResultSet rs=null;
try {
String sql ="select studentId,name,idCard,sex,age,grade from student";
rs=DBConnection.executeQuery(sql);
while(rs.next()){
String studentId=rs.getString(1);
String name=rs.getString(2);
String idCard=rs.getString(3);
String sex=rs.getString(4);
int age=rs.getInt(5);
int grade=rs.getInt(6);
Student student=new Student(studentId, name, idCard, sex, age, grade);
students.add(student);
}
} catch (Exception e) {
e.printStackTrace();
}finally{
if(rs!=null){
try {
rs.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
return students;
}
}
3.創(chuàng)建一個(gè)servlet 類名為L(zhǎng)istAllStudentServlet 配置屬性。 只改寫doGet() 方法。 因?yàn)榱硪粋€(gè)頁面需要獲取學(xué)生鏈表 可以 用轉(zhuǎn)發(fā)的方式進(jìn)行編寫。
內(nèi)容:
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
StudentDao studentDao=new StudentDao();
List<Student> students=studentDao.getAll();
request.setAttribute("students", students);
request.getRequestDispatcher("/student.jsp").forward(request, response); // 轉(zhuǎn)發(fā)
}
4.創(chuàng)建一個(gè)test.jsp 用于發(fā)送請(qǐng)求。
內(nèi)容:<a href="listAllStudent">List all students</a>
5.創(chuàng)建顯示頁面,student.jsp
內(nèi)容:
<body>
<%
List<Student> students=(List<Student>)request.getAttribute("students");
%>
<h3>學(xué)生信息表</h3>
<table>
<tr>
<th>studentId</th>
<th>name</th>
<th>idCard</th>
<th>sex</th>
<th>age</th>
<th>grade</th>
</tr>
<%
for(Student student:students){
%>
<tr>
<td><%=student.getStudentId() %></td>
<td><%=student.getName() %></td>
<td><%=student.getIdCard() %></td>
<td><%=student.getSex() %></td>
<td><%=student.getAge() %></td>
<td><%=student.getGrade() %></td>
</tr>
<% } %>
</table>
</body>
6.顯示

三、學(xué)習(xí)過程中遇到的問題
1.在連接sqlserver 數(shù)據(jù)庫時(shí) 出現(xiàn)了 這個(gè)問題。
問題:驅(qū)動(dòng)程序無法通過使用安全套接字層(SSL)加密與 SQL Server 建立安全連接。錯(cuò)誤:“Server key”。
解決方法:
這個(gè)問題是JDK與數(shù)據(jù)庫之間的安全秘鑰的問題。
方案就是:
1.下載兩個(gè)jar包
1.bcprov-ext-jdk15on-1.54.jar
2.bcprov-jdk15on-1.54.jar
下載地址在:http://download.csdn.net/detail/cw_hello1/9557049
2.將下載的兩個(gè)JAR文件復(fù)制到:JDK安裝目錄\jre\lib\ext下,例如我的就是D:\Program Files (x86)\java\JDK1.6\jre\lib\ext
3.打開java.security文件:在JDK安裝目錄\jre\lib\security下的java.security文件。
找到security.provider.1=sun.security.provider.Sun換成
security.provider.1=org.bouncycastle.jce.provider.BouncyCastleProvider
以上所述是小編給大家介紹的JavaWeb學(xué)習(xí)過程之MVC查詢模式詳解,希望對(duì)大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的,在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Java 實(shí)現(xiàn)將List平均分成若干個(gè)集合
這篇文章主要介紹了Java 實(shí)現(xiàn)將List平均分成若干個(gè)集合,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-08-08
手工體驗(yàn)smtp和pop3協(xié)議 郵件實(shí)現(xiàn)詳解(二)
POP3/IMAP協(xié)議定義了郵件客戶端軟件和POP3郵件服務(wù)器的通信規(guī)則,這篇文章我們就來手工體驗(yàn)SMTP和POP3協(xié)議的奧秘,感興趣的小伙伴們可以參考一下2017-10-10
Java開發(fā)SSM框架微信支付的實(shí)現(xiàn)
這篇文章主要介紹了Java開發(fā)SSM框架微信支付的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-10-10
Servlet第一個(gè)項(xiàng)目的發(fā)布(入門)
這篇文章主要介紹了Servlet第一個(gè)項(xiàng)目的發(fā)布,下面是用servlet實(shí)現(xiàn)的一個(gè)簡(jiǎn)單的web項(xiàng)目,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2021-04-04
java多線程之Future和FutureTask使用實(shí)例
這篇文章主要介紹了java多線程之Future和FutureTask使用實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09
基于hibernate框架在eclipse下的配置方法(必看篇)
下面小編就為大家?guī)硪黄趆ibernate框架在eclipse下的配置方法(必看篇)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09

