MVC

MVC指:Model模型、View视图、Controller控件器。

其中,各自的功能为:

View视图:为用户提供使用界面,与用户直接进行交互。

Model模型:承载数据,并对用户提交请求进行计算的模块。其分为两类,一类称为数据承载Bean,一类称为业务处理Bean。所谓数据承载Bean是指实体类,专门承载业务数据的,如Student、User等。而业务处理Bean则是指Service或Dao对象,专门用于处理用户提交请求的。

Controller控制器:用于将yoghurt请求转发给相应的Model进行处理,并处理Model的计算结果向用户提供相应响应。

MVC架构程序的工作流程:

(1)用户通过View页面向服务器端提出请求,可以是表单请求、超链接请求、AJAX请求等。

(2)服务端Controller控制器接收到请求后对请求进行解析,找到相应的Model对用户请求进行处理。

(3)Model处理后,将处理结果再交给Controller。

(4)Controller在接到处理结果后,根据处理结构找到要作为向客户端发回的View页面。页面经渲染(数据填充)后,再发送给客户端。


springmvc 中dao层和service层的区别

这个知识点转载自:

http://blog.csdn.net/dopamy_busymonkey/article/details/51422392

service是业务层,dao是数据访问层。

小白:在service里直接调用dao,service里面就new一个dao类对象,调用。

标准主流现在的编程方式都是采用MVC综合设计模式,MVC本身不属于设计模式的一种,它描述的是一种结构,最终目的达到解耦,解耦说的意思是你更改某一层代码,不会影响我其他层代码,如果你会像spring这样的框架,你会了解面向接口编程,表示层调用控制层,控制层调用业务层,业务层调用数据访问层。初期也许都是new对象去调用下一层,比如你在业务层new一个DAO类的对象,调用DAO类方法访问数据库,这样写是不对的,因为在业务层中是不应该含有具体对象,最多只能有引用,如果有具体对象存在,就耦合了。当那个对象不存在,我还要修改业务的代码,这不符合逻辑。好比主板上内存坏了,我换内存,没必要连主板一起换。我不用知道内存是哪家生产,不用知道多大容量,只要是内存都可以插上这个接口使用。这就是MVC的意义。


关于MVC与三层架构的解析学习参照之前转的博客:

http://blog.csdn.net/an1090239782/article/details/72804908

项目实践

以下就是实战,利用MVC设计模式场景,实现一个小的登录功能。

项目目录:

项目实现流程:

1:首先进入登录页面,输入用户名和密码。

2:将用户名和密码通过form表单提交给Controller进行操作,调研Javabean将数据传至接口LoginServiceImpl中。

3:在LoginServiceImpl中,该类实现接口LoginDaoImpl中的login方法。并将数据传至UserDaoImpl接口。

4:在UserDaoImpl接口实现对数据的相关操作,根据数据结果进行相关判断及使用。其中UserDaoImpl实现接口UserDao。

5:UserDao接口定义查询方法,查询数据库中是否存在该用户。

Login.jsp——>LoginServelet—–>LoginServiceImpl—–>UserDao—–>UserDaoImp。


JSP登录页面(View层)

JSP登录页面:

在登录页面填写用户名和密码,通过form表单提交请求给Login.action。

<body>
<form action="login.action">
用户名:<input type="text" name="uname" value="${param.uname }"><br/>
密码:<input type="password" name="pwd" value="${param.pwd }"><br/>
<input type="submit" value="登录"><br/>
<span style="color: red;">${requestScope.error }</span>
</form>
<a href="register.jsp">没有账号,立即注册</a>
</body>

LoginServlet.java(Controller控制层)

通过登录页面将数据传至LoginServlet,java。

通过注解配置LoginServlet.java。

@WebServlet(value="/login.action")

LoginServlet.java实现代码:

@WebServlet(value="/login.action")
public class LoginServlet extends HttpServlet { private LoginService service; public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String uname=request.getParameter("uname");
String pwd=request.getParameter("pwd");
//调用javabean
service=new LoginServiceImpl();
User user=service.login(uname, pwd);
//跳转jsp
if(user!=null) {
request.getSession().setAttribute("user", user);
response.sendRedirect("welcome.jsp");
} else {
request.setAttribute("error", "登录失败请重新输入");
request.getRequestDispatcher("login.jsp").forward(request, response);
}
}
}

LoginServiceImpl.java(实现接口LoginService)

LoginServiceImpl.java实现代码:

public class LoginServiceImpl implements LoginService {

    private UserDao dao=new UserDaoImpl();
@Override
public User login(String uname, String pwd) {
// TODO Auto-generated method stub
//业务处理
User user=new User(uname,pwd);
return dao.findUser(user);
} }

UserDao.java

接口UserDao,java中实现关于用户的数据访问的相关方法。

实现代码:

public interface UserDao {

    //查询
User findUser(User user); //删除 }

UserDaoImp.java(继承自Oracle数据库连接池,实现接口UserDao)

UserDaoImpl,java继承了JNDIBaseDao,实现从数据库中查找是否存在该数据,实现方法为UserDao中的查询方法。

public class UserDaoImpl extends JNDIBaseDao implements UserDao

实现代码:

public class UserDaoImpl extends JNDIBaseDao implements UserDao {

    @Override
public User findUser(User user) {
// TODO Auto-generated method stub
//3.执行sql语句
//4.获取结果集
String sql = "select * from user where 1=1";
ArrayList list = new ArrayList();
if(user.getUname()!=null&&!user.getUname().equals("")){
sql+=" and uname=? ";
list.add(user.getUname());
}
ResultSet rs=executeQuery(sql, list.toArray());
//访问数据库查询是否存在该用户
try {
//登录成功
if(rs.next()) {
//把结果集转换成实体类
user.setUname(rs.getString("uname"));
user.setPwd(rs.getString("pwd"));
user.setId(rs.getInt("id"));
user.setSex(rs.getString("sex"));
user.setEmail(rs.getString("email"));
return user;
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//不存在该用户
return null;
} }

JNDIBaseDao.java

在JNDIBaseDao中,通过连接池方法实现与Oracle数据库的交互,并实现对数据库之中的相关操作,如增删改查等。

实现代码:

public class JNDIBaseDao {

    private DataSource source;
private Connection connection;
private PreparedStatement ps;
private ResultSet rs; {
try {
Context ic = new InitialContext();
source = (DataSource)ic.lookup("java:comp/env/jdbc/test");
} catch (NamingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} public void getConnection() {
try {
connection=source.getConnection();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} /**
* 增删改操作
* @param sql
* @param objs
* @return 影响行数
*/
public int executeUpdate(String sql,Object... objs) {
if(connection==null) {
getConnection();
}
int res=-1;
try {
//设置手动提交事务
connection.setAutoCommit(false);
connection.setTransactionIsolation(Connection.TRANSACTION_READ_COMMITTED);
ps=connection.prepareStatement(sql);
if(objs!=null) {
for(int i=0;i<objs.length;i++) {
ps.setObject(i+1, objs[i]);
}
}
res=ps.executeUpdate();
//手动提交事务
connection.commit();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
try {
connection.rollback();
} catch (SQLException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
} finally {
if(ps!=null) {
try {
ps.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
return res;
} /**
* 查询操作
* @param sql
* @param objs
* @return
*/
public ResultSet executeQuery(String sql,Object... objs) {
if(connection==null) {
getConnection();
}
try {
ps=connection.prepareStatement(sql);
if(objs!=null) {
for(int i=0;i<objs.length;i++) {
ps.setObject(i+1, objs[i]);
}
}
rs=ps.executeQuery();
return rs;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
} public void closeAll() {
try {
if(rs!=null) {
rs.close();
}
if(ps!=null) {
ps.close();
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

BaseDao(JDBC交互数据库)

JDBC方式连接数据库与数据库实现相关交互操作。

public class BaseDao {

    private String driver="oracle.jdbc.driver.OracleDriver";
private String url="jdbc:oracle:thin:@localhost:1521:jredu";
private String username="test";
private String password="Jredu12345";
private Connection connection;
private PreparedStatement ps;
private ResultSet rs; public void getConnection() {
try {
Class.forName(driver);
connection=DriverManager.getConnection(url,username,password);
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} /**
* 增删改操作
* @param sql
* @param objs
* @return 影响行数
*/
public int executeUpdate(String sql,Object... objs) {
if(connection==null) {
getConnection();
}
try {
ps=connection.prepareStatement(sql);
if(objs!=null) {
for(int i=0;i<objs.length;i++) {
ps.setObject(i+1, objs[i]);
}
}
return ps.executeUpdate();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
closeStatement();
}
return 0;
} /**
* 查询操作
* @param sql
* @param objs
* @return
*/
public ResultSet executeQuery(String sql,Object... objs) {
if(connection==null) {
getConnection();
}
try {
ps=connection.prepareStatement(sql);
if(objs!=null) {
for(int i=0;i<objs.length;i++) {
ps.setObject(i+1, objs[i]);
}
}
rs=ps.executeQuery();
return rs;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
} /**
* 关闭声明
*/
public void closeStatement() {
try {
if (ps != null) {
ps.close();
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } /**
* 把结果集和声明同时关闭
*/
public void closeAll() {
try {
if(rs!=null) {
rs.close();
}
if(ps!=null) {
ps.close();
}
if(connection!=null) {
connection.close();
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

至此,一个完整的MVC开发流程描述完毕,具体相关代码及操作,如有疑问可留言讨论,新手小白学习,还望大佬们赐教。如有雷同,纯属巧合。

MVC架构 项目实践的更多相关文章

  1. 使用Asp.Net Core MVC 开发项目实践[第一篇:项目结构说明]

    先从下图看整体项目结构: Mango.Manager: 为后台管理项目 Mango.Web: 为前台项目 Mango.Framework.Core: 为常用的基础操作类项目 Mango.Framewo ...

  2. 使用Asp.Net Core MVC 开发项目实践[第五篇:缓存的使用]

    项目中我们常常会碰到一些数据,需要高频率用到但是又不会频繁变动的这类,我们就可以使用缓存把这些数据缓存起来(比如说本项目的导航数据,帖子频道数据). 我们项目中常用到有Asp.Net Core 本身提 ...

  3. Asp.Net MVC大型项目实践整合 NHibernate与Json序列化

    通过NHibernate我们多表查询是实现了 但由于查询出来的集合中的对象“不是平的”,如何在送到UI绑定成了问题.ExtJs UI组件的数据绑定支持多种格式,如简单数组,Json,Xml.在本项目中 ...

  4. 使用Asp.Net Core MVC 开发项目实践[第三篇:基于EF Core的扩展]

    上篇我们说到了EFCore的基础使用,这篇我们将讲解下基于EFCore的扩展. 我们在Mango.Framework.EFCore类库项目中创建一个类名EFExtended的扩展类,并且引入相关的命名 ...

  5. 使用Asp.Net Core MVC 开发项目实践[第二篇:EF Core]

    在项目中使用EF Core还是比较容易的,在这里我们使用的版本是EF Core 2.2. 1.使用nuget获取EF Core包 这个示例项目使用的是SQLSERVER,所以还需要下载Microsof ...

  6. 使用Asp.Net Core MVC 开发项目实践[第四篇:基于EF Core的扩展2]

    上篇我们说到了基于EFCore的基础扩展,这篇我们讲解下基于实体结合拉姆达表达式的自定义更新以及删除数据. 先说下原理:其实通过实体以及拉姆达表达式生成SQL语句去执行 第一种更新扩展: 自定义更新字 ...

  7. MVC项目实践,在三层架构下实现SportsStore,从类图看三层架构

    在"MVC项目实践,在三层架构下实现SportsStore-02,DbSession层.BLL层"一文的评论中,博友浪花一朵朵建议用类图来理解本项目的三层架构.于是就有了本篇: I ...

  8. MVC项目实践,在三层架构下实现SportsStore-02,DbSession层、BLL层

    SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...

  9. MVC项目实践,在三层架构下实现SportsStore-01,EF Code First建模、DAL层等

    SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...

随机推荐

  1. 一个关于JVM类初始化问题

    刚在看虚拟机相关知识点 看到一段代码,大家猜测一下这段代码会触发子类初始化吗 public class SuperClass{ static{ system.out.println("Sup ...

  2. jdbc事务、连接池概念、c3p0、Driud、JDBC Template、DBUtils

    JDBC 事务控制 什么是事务:一个包含多个步骤或者业务操作.如果这个业务或者多个步骤被事务管理,则这多个步骤要么同时成功,要么回滚(多个步骤同时执行失败),这多个步骤是一个整体,不可分割的. 操作: ...

  3. Hive表的基本操作

    目录 1. 创建表 2. 拷贝表 3. 查看表结构 4. 删除表 5. 修改表 5.1 表重命名 5.2 增.修.删分区 5.3 修改列信息 5.4 增加列 5.5 删除列 5.6 修改表的属性 1. ...

  4. pixi.js 自定义光标样式

    pixi 介绍 Pixi是一个超快的2D渲染引擎,通过Javascript和Html技术创建动画或管理交互式图像,从而制作游戏或应用. 项目地址:https://github.com/pixijs/p ...

  5. 实现Vue的多页签组件

    在之前的博客中  关于vue的多页面标签功能,对于嵌套router-view缓存的最终无奈解决方法  有写过vue的多页签功能的解决方案 可以看到我当时那个多页签的组件还是比较简单 的,只有打开跟关闭 ...

  6. Redis集群搭建与简单使用【转】

    Redis集群搭建与简单使用 安装环境与版本 用两台虚拟机模拟6个节点,一台机器3个节点,创建出3 master.3 salve 环境. redis 采用 redis-3.2.4 版本. 两台虚拟机都 ...

  7. Spark内核解析

    Spark内核概述 Spark内核泛指Spark的核心运行机制,包括Spark核心组件的运行机制.Spark任务调度机制.Spark内存管理机制.Spark核心功能的运行原理等,熟练掌握Spark内核 ...

  8. 一文搞懂MySQL前缀索引

    引入 通常在开发中我们需要定义字符串类型的字段,例如用户名或者用户邮箱等. 假设我们在维护一个用户登录系统,用户表的定义: create table User( ID bigint unsigned ...

  9. 基于JavaFX实现的音乐播放器

    前言 这个是本科四年的毕业设计,我个人自命题的一个音乐播放器的设计与实现,其实也存在一些功能还没完全开发完成,但粗略的答辩也就过去了,还让我拿了个优秀,好开心.界面UI是参考网易云UWP版本的,即使这 ...

  10. 串口使用Pipeline时诡异的ReadOnlySequence问题

    借鉴之前的Pipeline的操作方式,现在目标是给串口读取操作也使用上Pipeline.稍微改造一下,以下代码可以直接运行. 协议为使用连续的4个0XFF作为结尾,没有头标志.数据总长为68位定长. ...