目录
Maven中的继承是针对于父工程和子工程。父工程定义的依赖和插件子工程可以直接使用。注意父工程类型一定为POM类型工程。
多继承
在Maven中对于继承采用的也是单继承,也就是说一个子项目只能有一个父项目。但我们可以在 <dependencyManagement> 配置多继承的。
写法如下:

dao子工程中一般写实体类和dao层:
在父工程下创建maven模块,不选择模板,创建时一定要选择父工程。


子模块的pom文件中写入父工程证明继承成功。 如下图所示:

准备数据库
//新建数据库
CREATE DATABASE student;
//建表
CREATE TABLE student(
id int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
name varchar(255) DEFAULT NULL,
sex varchar(10) DEFAULT NULL,
address varchar(255) DEFAULT NULL
)ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT
CHARSET=utf8
//插入数据
insert into student values(1,'几何心凉','男','北京');
insert into student values(2,'哈士奇','女','上海');
编写实体类 Student
package com.mavenstudy.pojo;
public class Student {
private int id;
private String name;
private String sex;
private String address;
public Student(){
}
public Student(int id, String name, String sex, String address) {
this.id = id;
this.name = name;
this.sex = sex;
this.address = address;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
@Override
public String toString() {
return "Student [" +
"id=" + id +
", name='" + name + '\'' +
", sex='" + sex + '\'' +
", address='" + address + '\'' +
']';
}
}
在resources中编写连接数据库的配置文件db.properties,

编写dao类和对应的方法
package com.mavenstudy.dao;
import com.mavenstudy.pojo.Student;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;
public class StudentDao {
//查询所有学生
public List<Student> findAll() throws Exception{
//读取配置文件
Properties properties = new Properties();
InputStream is = this.getClass().getClassLoader().getResourceAsStream("db.properties");
properties.load(is);
String url = properties.getProperty("jdbc.url");
String user = properties.getProperty("jdbc.user");
String password = properties.getProperty("jdbc.password");
//查询数据库
Connection connection = DriverManager.getConnection(url,user,password);
Statement statement = connection.createStatement();
ResultSet resultSet = statement.executeQuery("select * from student");
//处理结果集
List<Student> students = new ArrayList<>();
while(resultSet.next()){
int id = resultSet.getInt(1);
String name = resultSet.getString(2);
String sex = resultSet.getString(3);
String address = resultSet.getString(4);
Student student = new Student(id,name,sex,address);
students.add(student);
}
//释放资源
resultSet.close();
statement.close();
connection.close();
return students;
}
}
测试dao方法 这里我们可以用到Junit这个注解来帮我们测试

现在让我们来运行一下是否真的能够执行吧!
OK!,确实是没有问题的,那接下来我们搭建service模块
service子工程中一般写service层的内容,也需要继承父工程,由于需要调用dao子工程的方法,所以需要导入dao子工程的依赖。
在父工程下创建maven模块,不选择模板,选择父工程。(这里和上面都是一样的就不截图了)
在service模块的pom文件中引入dao子工程的依赖。
<dependencies>
<dependency>
<groupId>com.mavenstudy</groupId>
<artifactId>maven_demo2_dao</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
编写Service类和对应的方法
package com.mavenstudy.service;
import com.mavenstudy.dao.StudentDao;
import com.mavenstudy.pojo.Student;
import java.util.List;
public class StudentService {
private StudentDao studentDao = new StudentDao();
public List<Student> findAllStudent() throws Exception{
return studentDao.findAll();
}
}
编写测试service方法
package com.mavenstudy.service;
import com.mavenstudy.pojo.Student;
import org.junit.Test;
import java.util.List;
public class StudentServiceTest {
//测试findAllStudent
@Test
public void findAllStudentTest() throws Exception {
StudentService studentService = new StudentService();
List<Student> students = studentService.findAllStudent();
students.forEach(System.out::println);
}
}
测试结果

OK!结果还是和我们预想的一样,接下来让我们搭建web模块吧!
web子工程中一般要写控制器和前端页面的内容。它不是普通的java工程,而是一个web工程,需要继承父工程,导入service子工程的依赖。
在父工程下创建maven模块,选择web工程模板,选择父工程。


创建好后,添加父工程,删除pom文件中的jdk编译版本,删掉junit依赖,引入service依赖。
<dependencies>
<dependency>
<groupId>com.mavenstudy</groupId>
<artifactId>maven_demo2_service</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
编写控制器,FindAllStudentServlet类
package com.mavenstudy.servlet;
import com.mavenstudy.pojo.Student;
import com.mavenstudy.service.StudentService;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.List;
@WebServlet("/allStudent")
public class FindAllStudentServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
StudentService studentService = new StudentService();
List<Student> students = null;
try {
students = studentService.findAllStudent();
} catch (Exception e) {
e.printStackTrace();
}
req.setAttribute("students",students);
req.getRequestDispatcher("allStudent.jsp").forward(req,resp);
}
}
编写JSP页面 ,其中我们需要用到EL表达式,但是maven是默认不识别EL表达式的,所以我们需要加上一个属性 isELIgnored="false" 和 一个引入
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
显示所有学生信息的jsp页面
<%@ page contentType="text/html;charset=UTF-8" language="java"
isELIgnored="false" %>
<%@taglib prefix="c"
uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>
全部学生
</title>
</head>
<body>
<table align="center" border="1" cellspacing="0" cellpadding="0" width="500px">
<tr>
<th>id</th>
<th>姓名</th>
<th>性别</th>
<th>地址</th>
</tr>
<c:forEach items="${students}" var="student">
<tr>
<td>${student.id}</td>
<td>${student.name}</td>
<td>${student.sex}</td>
<td>${student.address}</td>
</tr>
</c:forEach>
</table>
</body>
</html>
配置tomcat插件运行父工程,此时会自动聚合运行项目。
点开配置tomcat7插件


OK!配置完点击运行按钮即可 ,下面就是运行结果

我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我正在查看instance_variable_set的文档并看到给出的示例代码是这样做的:obj.instance_variable_set(:@instnc_var,"valuefortheinstancevariable")然后允许您在类的任何实例方法中以@instnc_var的形式访问该变量。我想知道为什么在@instnc_var之前需要一个冒号:。冒号有什么作用? 最佳答案 我的第一直觉是告诉你不要使用instance_variable_set除非你真的知道你用它做什么。它本质上是一种元编程工具或绕过实例变量可见性的黑客攻击
在我的应用程序中,我需要能够找到所有数字子字符串,然后扫描每个子字符串,找到第一个匹配范围(例如5到15之间)的子字符串,并将该实例替换为另一个字符串“X”。我的测试字符串s="1foo100bar10gee1"我的初始模式是1个或多个数字的任何字符串,例如,re=Regexp.new(/\d+/)matches=s.scan(re)给出["1","100","10","1"]如果我想用“X”替换第N个匹配项,并且只替换第N个匹配项,我该怎么做?例如,如果我想替换第三个匹配项“10”(匹配项[2]),我不能只说s[matches[2]]="X"因为它做了两次替换“1fooX0barXg
我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm
我有一个正在构建的应用程序,我需要一个模型来创建另一个模型的实例。我希望每辆车都有4个轮胎。汽车模型classCar轮胎模型classTire但是,在make_tires内部有一个错误,如果我为Tire尝试它,则没有用于创建或新建的activerecord方法。当我检查轮胎时,它没有这些方法。我该如何补救?错误是这样的:未定义的方法'create'forActiveRecord::AttributeMethods::Serialization::Tire::Module我测试了两个环境:测试和开发,它们都因相同的错误而失败。 最佳答案
我正在处理旧代码的一部分。beforedoallow_any_instance_of(SportRateManager).toreceive(:create).and_return(true)endRubocop错误如下:Avoidstubbingusing'allow_any_instance_of'我读到了RuboCop::RSpec:AnyInstance我试着像下面那样改变它。由此beforedoallow_any_instance_of(SportRateManager).toreceive(:create).and_return(true)end对此:let(:sport_
我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI
这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub
我正在玩HTML5视频并且在ERB中有以下片段:mp4视频从在我的开发环境中运行的服务器很好地流式传输到chrome。然而firefox显示带有海报图像的视频播放器,但带有一个大X。问题似乎是mongrel不确定ogv扩展的mime类型,并且只返回text/plain,如curl所示:$curl-Ihttp://0.0.0.0:3000/pr6.ogvHTTP/1.1200OKConnection:closeDate:Mon,19Apr201012:33:50GMTLast-Modified:Sun,18Apr201012:46:07GMTContent-Type:text/plain
我收到格式为的回复#我需要将其转换为哈希值(针对活跃商家)。目前我正在遍历变量并执行此操作:response.instance_variables.eachdo|r|my_hash.merge!(r.to_s.delete("@").intern=>response.instance_eval(r.to_s.delete("@")))end这有效,它将生成{:first="charlie",:last=>"kelly"},但它似乎有点hacky和不稳定。有更好的方法吗?编辑:我刚刚意识到我可以使用instance_variable_get作为该等式的第二部分,但这仍然是主要问题。