激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - JavaWeb搭建網上圖書商城畢業設計

JavaWeb搭建網上圖書商城畢業設計

2020-01-13 17:37lijiao JAVA教程

這篇文章主要介紹了JavaWeb搭建網上圖書商城框架,特別適合正在為網上商城畢業設計煩惱的同學,需要的朋友可以參考下

  以前一直接觸.net相關的web開發,現在猛然使用javaWeb還是很不習慣,就連搭個框架也是第一次。

一、談談項目架構
  一開始接觸.net相關的開發所以對于.net相關的開發還是比較熟悉的,但我在學校學的java方向的開發,而我打算把這兩種平臺結合起來,使用java做后臺也就是服務提供者,將所有業務邏輯在java平臺完成并使用我比較熟悉的.net做Web端的開發。這樣一來安卓app,web端就都有了。客戶端統一通過分布式框架調用服務。找了很久最終選擇了Hprose,這一輕量級、跨語言、跨平臺、無侵入式、高性能動態遠程對象調用引擎庫。之所以選擇它一方面是因為學習成本低,另一方面是它的跨平臺調用非常輕松高效,因為我們要使用.net做web需要調用java發布的服務!大概看了一下Hprose的文檔,發現使用內置的HproseServlet發布服務開發速度比較快也比較簡單,所以準備使用這種方式發布服務。可問題來了,傳統的ssh架構感覺有點重了,準備使用.net開發web端所以感覺沒有必要整合Struts,于是就是hibernate+spring+hprose這種架構。

二、數據庫設計

  一個小網上書城,所以設計的還有欠缺,以實用為主,主要是練手java開發~~。所以使用了navicat簡單設計了一下,不過沒有設計表關聯,取而代之的是后來一個一個添加關系的,發現這個設計工具有點問題,圖示:

JavaWeb搭建網上圖書商城畢業設計

其實表關聯一看就能看出來~~,接下來就是hibernate一些映射了,同樣也是使用插件生成model和映射文件

JavaWeb搭建網上圖書商城畢業設計

稍作修改就是這樣--

JavaWeb搭建網上圖書商城畢業設計

三、spring3+hibernate4配置
  因為model和映射文件是自動生成所以稍加配置就好,需要注意的是復合主鍵的設置,自動生成的會把復合主鍵對應一個復合模型。如商品評論表的復合主鍵類型

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
package com.book.model;
// Generated 2015-11-2 9:07:06 by Hibernate Tools 4.0.0.Final
 
import java.util.Date;
 
/**
 * CommentsId generated by hbm2java
 */
public class CommentsPk implements java.io.Serializable {
 
  private Book book;
  private User user;
  private Date commentsDate;
 
  public CommentsPk() {
  }
 
  public CommentsPk(Book book, User user, Date commentsDate) {
    this.book = book;
    this.user = user;
    this.commentsDate = commentsDate;
  }
 
  public Book getBook() {
    return this.book;
  }
 
  public void setBook(Book book) {
    this.book = book;
  }
 
  public User getUser() {
    return this.user;
  }
 
  public void setUser(User user) {
    this.user = user;
  }
 
  public Date getCommentsDate() {
    return this.commentsDate;
  }
 
  public void setCommentsDate(Date commentsDate) {
    this.commentsDate = commentsDate;
  }
 
  public boolean equals(Object other) {
    if ((this == other))
      return true;
    if ((other == null))
      return false;
    if (!(other instanceof CommentsPk))
      return false;
    CommentsPk castOther = (CommentsPk) other;
 
    return ((this.getBook() == castOther.getBook()) || (this.getBook() != null && castOther.getBook() != null
        && this.getBook().equals(castOther.getBook())))
        && ((this.getUser() == castOther.getUser()) || (this.getUser() != null && castOther.getUser() != null
            && this.getUser().equals(castOther.getUser())))
        && ((this.getCommentsDate() == castOther.getCommentsDate())
            || (this.getCommentsDate() != null && castOther.getCommentsDate() != null
                && this.getCommentsDate().equals(castOther.getCommentsDate())));
  }
 
  public int hashCode() {
    int result = 17;
 
    result = 37 * result + (getBook() == null ? 0 : this.getBook().hashCode());
    result = 37 * result + (getUser() == null ? 0 : this.getUser().hashCode());
    result = 37 * result + (getCommentsDate() == null ? 0 : this.getCommentsDate().hashCode());
    return result;
  }
 
}

商品評論表模型

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package com.book.model;
// Generated 2015-10-30 14:56:21 by Hibernate Tools 4.0.0.Final
 
import java.sql.Date;
 
/**
 * Comments generated by hbm2java
 */
public class Comments implements java.io.Serializable {
 
  private String content;
  private String pic;
  private Integer client;
  private CommentsPk id;
  public Comments()
  {
    
  }
  public String getContent() {
    return content;
  }
  public void setContent(String content) {
    this.content = content;
  }
  public String getPic() {
    return pic;
  }
  public void setPic(String pic) {
    this.pic = pic;
  }
  public Integer getClient() {
    return client;
  }
  public void setClient(Integer client) {
    this.client = client;
  }
  public CommentsPk getId() {
    return id;
  }
  public void setId(CommentsPk id) {
    this.id = id;
  }
  public Comments(String content, String pic, Integer client, CommentsPk id) {
    super();
    this.content = content;
    this.pic = pic;
    this.client = client;
    this.id = id;
  }
  
}

相應的Hibernate 映射文件:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!-- Generated 2015-10-30 14:56:21 by Hibernate Tools 4.0.0.Final -->
<hibernate-mapping>
  <class name="com.book.model.Comments" table="comments" catalog="bookstore">
    <composite-id name="id" class="com.book.model.CommentsPk">
      <key-many-to-one name="book" class="com.book.model.Book">
        <column name="BookID" />
      </key-many-to-one>
      <key-many-to-one name="user" class="com.book.model.User">
        <column name="UserID" />
      </key-many-to-one>
      <key-property name="commentsDate" type="timestamp">
        <column name="CommentsDate" length="19" />
      </key-property>
    </composite-id>
    <property name="content" type="string">
      <column name="Content" length="65535" />
    </property>
    <property name="pic" type="string">
      <column name="Pic" length="65535" />
    </property>
    <property name="client" type="java.lang.Integer">
      <column name="Client" />
    </property>
  </class>
</hibernate-mapping>

因為商品評論表有兩個是外鍵所以使用了key-many-to-one標簽。

由于采用spring3.2+hibernate4.1所以得到sessionFactory的方式只限于sessionFactory.getCurrentSession();但是必須開啟事物:   

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<bean id="transactionManager"
   class="org.springframework.orm.hibernate4.HibernateTransactionManager">
   <property name="sessionFactory" ref="sessionFactory" />
 </bean>
 
 <!-- 事務的傳播特性 -->
 <tx:advice id="txadvice" transaction-manager="transactionManager">
   <tx:attributes>
     <tx:method name="add*" propagation="REQUIRED" />
     <tx:method name="delete*" propagation="REQUIRED" />
     <tx:method name="modify*" propagation="REQUIRED" />
     
      <!--hibernate4必須配置為開啟事務 否則 getCurrentSession()獲取不到-->
     <tx:method name="*" propagation="REQUIRED" read-only="true" />
   </tx:attributes>
 </tx:advice>

以上都是我配置的時候出現問題的地方。下面是spring配置文件:

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
  xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
    http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd">
    
    <!-- 啟用spring注解支持 -->
  <context:annotation-config />
  
  <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="com.mysql.jdbc.Driver" />
    <property name="url"
      value="jdbc:mysql://127.0.0.1/bookstore?useUnicode=true&characterEncoding=UTF-8" />
    <property name="username" value="root" />
    <property name="password" value="yangyang" />
  </bean>
 
  <!-- 可追加配置二級緩存 -->
  <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean" >
    <property name="dataSource" ref="dataSource"/>
    <property name="mappingDirectoryLocations">
       <list>
         <value>classpath:config</value>
       </list>
    </property>
    <property name="hibernateProperties">
      <props>
        <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
        <prop key="hibernate.show_sql">true</prop>
        <prop key="hibernate.hbm2ddl.auto">update</prop>
        <prop key="hibernate.temp.use_jdbc_metadata_defaults">false</prop>
        <prop key="current_session_context_class">thread</prop>
      </props>
    </property>
  </bean>
  
 
    <!-- 配置事務管理器 -->
  <bean id="transactionManager"
    class="org.springframework.orm.hibernate4.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
  </bean>
  
  <!-- 事務的傳播特性 -->
  <tx:advice id="txadvice" transaction-manager="transactionManager">
    <tx:attributes>
      <tx:method name="add*" propagation="REQUIRED" />
      <tx:method name="delete*" propagation="REQUIRED" />
      <tx:method name="modify*" propagation="REQUIRED" />
      
       <!--hibernate4必須配置為開啟事務 否則 getCurrentSession()獲取不到-->
      <tx:method name="*" propagation="REQUIRED" read-only="true" />
    </tx:attributes>
  </tx:advice>
 
  <!-- 那些類那些方法使用事務 -->
  <aop:config>
   <!-- 只對業務邏輯層實施事務 -->
    <aop:pointcut id="allManagerMethod"
      expression="execution(* com.book.test.*.*(..))" />
    <aop:advisor pointcut-ref="allManagerMethod" advice-ref="txadvice" />
  </aop:config>
    <bean name="basedao" class="com.book.dao.impl.AdressDao" />
    <bean name="orderdao" class="com.book.dao.impl.OrderDao" />
</beans>

一切就緒之后我們使用servlet測試:

?
1
2
3
4
5
6
7
8
<servlet>
  <servlet-name>test</servlet-name>
  <servlet-class>com.book.test.Test</servlet-class>
 </servlet>
 <servlet-mapping>
  <servlet-name>test</servlet-name>
  <url-pattern>/index</url-pattern>
 </servlet-mapping>
   
?
1
2
3
4
5
6
7
8
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
   // TODO Auto-generated method stub
   BeanFactory factor = WebApplicationContextUtils.getRequiredWebApplicationContext(request.getSession().getServletContext());
   OrderDao dao= factor.getBean(OrderDao.class);
   
   Object[] list= dao.get(1).getOrderitems().toArray();
   System.out.println(((Orderitem)list[0]).getOrdercount());   
 }

因為沒有使用structs我們需要自己查找spring的BeanFactory來獲得dao bean 這也是需要注意的地方,糾結好久。

運行結果:

JavaWeb搭建網上圖書商城畢業設計

 成功加載訂單表訂單1項目訂購數量。

 畢竟第一次使用java開發這類項目,慢慢學習吧,希望大家可以喜歡JavaWeb搭建的網上圖書商城框架,對大家的學習有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩中文字幕一区二区三区 | 国产精品免费一区二区三区都可以 | 色日本视频 | 91成人在线网站 | 欧美精品免费一区二区三区 | 欧美黄色免费视频 | 91精品国产综合久久婷婷香蕉 | 亚洲第一成人在线观看 | 凹凸成人精品亚洲精品密奴 | 午夜国产在线 | 午夜天堂在线 | 欧美成人精品不卡视频在线观看 | 请播放一级毛片 | 国产高清自拍一区 | 国产亚洲精品久久久久5区 男人天堂免费 | 欧洲精品久久久 | 国产在线观看一区二区三区 | 精品久久久久久久久中文字幕 | 亚洲成人精品久久久 | 日韩黄色片免费看 | 性少妇freeseⅹbbwhd | 久久99国产精品久久99 | 51国产偷自视频区视频小蝌蚪 | 91久久线看在观草草青青 | 精品国产一区二区三区四区阿崩 | 91 在线观看 | 欧美a久久| 成人午夜视频在线观看免费 | 日本a∨精品中文字幕在线 国产精品片www48888 | 久久在草 | 久草在线播放视频 | 91久久久久久久久久 | 在线看一区二区三区 | 精品国产一区二区三区四区阿崩 | 欧美黄色一级片在线观看 | 91在线色 | 一区二区国产在线 | 3xxx| 99精品国产在热久久婷婷 | 成人爱爱电影 | 国产成年人网站 |