目录
前言
前言:
1.配置文件有啥好处?
.properties/.xml/.yml
1)使代码更加灵活
2)维护性更高
2.各个地方的位置有啥讲究?
同一层级:方便同步编码 Mybatis
根目录:一般不做频繁更改
web-inf下:安全目录
1.读取各个位置下的配置文件
一、三种配置文件的配置位置和获取方式
1.1 同一层级
首先我们讲一下配置文件放在同一层级的好处:方便同步编码
下面展示 同一层级获取代码
。
package yzpparse;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
/**
* 读取各个位置文件
* @author 易泽鹏
*
* 2022年6月14日上午8:39:06
*/
public class YzpDemo1 {
public static void main(String[] args) throws Exception {
// 同包
InputStream in = YzpDemo1.class.getResourceAsStream("db.properties");
// .properties文件又一个专门类解析
Properties p = new Properties();
//此时p 就加载了db.properties的所有信息
p.load(in);
System.out.println(p.getProperty("uname"));
System.out.println(p.getProperty("upass"));
1.2 根目录获取位置方法
为什么要放在根目录:一般不做频繁更改
下面展示一些 根目录获取位置方法
。
package yzpparse;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
/**
* 读取各个位置文件
* @author 易泽鹏
*
* 2022年6月14日上午8:39:06
*/
public class YzpDemo1 {
public static void main(String[] args) throws Exception {
//根目录
InputStream in = YzpDemo1.class.getResourceAsStream("/db.properties");
// .properties文件又一个专门类解析
Properties p = new Properties();
//此时p 就加载了db.properties的所有信息
p.load(in);
System.out.println(p.getProperty("uname"));
System.out.println(p.getProperty("upass"));
1.3 web-inf
放在web-inf的是因为web-inf属于安全目录
下面展示 web-inf获取文件代码
。
package yzpparse;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* 获取web-inf的文件位置以及解析文件
* @author 易泽鹏
*
* 2022年6月14日上午11:13:04
*/
@WebServlet("/a")
public class WebInfServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doPost(request, response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// request.getRequestDispatcher("/WEB-INF/a.jsp").forward(request, response);
// 拿到servlet的上下文
InputStream in = request.getServletContext().getResourceAsStream("WEB-INF/db.properties");
Properties p = new Properties();
p.load(in);
System.out.println(p.getProperty("uname"));
System.out.println(p.getProperty("upass"));
}
二、dom4j的四种方法
注释:selectNodes这个方法是可以拿到指定对象的所有内容,根据标签名,返回单个标签,通常用于已经知晓该标签只会出现一次
selectsingNodes这个方法是拿到单个
attributeValuE是拿到属性值
getText拿到标签里的内容
下面展示 使用这些方法的代码
。
package yzpparse;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
public class YzpDemo2 {
public static void main(String[] args) throws Exception {
InputStream in = YzpDemo2.class.getResourceAsStream("students.xml");
SAXReader sr = new SAXReader();
//将配置文件中的所有内容获取到了
Document doc = sr.read(in);
// selectNodes 根据标签名,返回标签集合
// System.out.println(doc.asXML());
// List<Element> studentsEles = doc.selectNodes("students");
// System.out.println(studentsEles.size());
// List<Element> studentEles = studentsEles.get(0).selectNodes("student");
// System.out.println(studentEles.size());
// selectNodes 根据标签名,返回单个标签,通常用于已经知晓该标签只会出现一次
Element studentsEle = (Element)doc.selectSingleNode("students");
List<Element> studentEles = studentsEle.selectNodes("student");
for (Element stuEle : studentEles) {
System.out.println(stuEle.attributeValue("sid"));//attributeValuE是拿到属性值
System.out.println(stuEle.selectSingleNode("name").getText());//getText拿到标签里的内容
}
}
}
三、xpath的使用
简单解释一下 //*[@id=“-layout”]/div/div[2]/section/div[5]/div[2]/div[2]/ul/li[1]/div[2]/p[1]
// /代表层级,代表查找
// @精准定位
下面展示一些 xpath的使用代码
。
package yzpparse;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
public class YzpDemo3 {
public static void main(String[] args) throws Exception {
//*[@id="-layout"]/div/div[2]/section/div[5]/div[2]/div[2]/ul/li[1]/div[2]/p[1]
// /代表层级,代表查找
// @精准定位
//读出文件的内容
InputStream in = YzpDemo3.class.getResourceAsStream("students.xml");
SAXReader sr = new SAXReader();
Document doc = sr.read(in);
// Element stus002 = (Element) doc.selectSingleNode("/students/student[@sid='s002']/name");
// System.out.println(stus002.getText());
//拿到students的所有内容
Element studentsEle = (Element) doc.selectSingleNode("students");
//拿到students的所有student
List<Element> stuEles = studentsEle.selectNodes("student");
//foreach遍历得到所有的sid和name值
for (Element stuEle : stuEles) {
if("s002".equals(stuEle.attributeValue("sid"))) {
System.out.println(stuEle.selectSingleNode("name").getText());
}
}
}
}
四、使用案例
案例1 拿到action里面的所有type值
package yzpparse;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
import jdk.management.resource.internal.inst.SocketOutputStreamRMHooks;
/**
* 拿到action里面的所有type值
* @author 易泽鹏
*
* 2022年6月14日上午9:40:13
*/
public class YzpDemo4 {
public static void main(String[] args) throws Exception {
//案例一:拿到action里面的所有type值
InputStream in = YzpDemo4.class.getResourceAsStream("config.xml");
SAXReader sr = new SAXReader();
Document doc = sr.read(in);
//拿到config标签里面的所有东西
Element configs = (Element) doc.selectSingleNode("config");
//拿到action集合
List<Element> configEles = configs.selectNodes("action");
//循环遍历拿到所有的type值
for (Element ation : configEles) {
System.out.println(ation.attributeValue("type"));
}
}
}
案例2 获取第二个type值
package yzpparse;
import java.io.InputStream;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
/**
* 获取第二个type值
* @author 易泽鹏
*
* 2022年6月14日上午10:09:45
*/
public class YzpDemo5 {
public static void main(String[] args) throws Exception {
// 案例2获取第二个type值:做题思路通过@精准定位拿到第二个action
InputStream in = YzpDemo4.class.getResourceAsStream("config.xml");
SAXReader sr = new SAXReader();
Document doc = sr.read(in);
//path值找到完成的action
Element action = (Element) doc.selectSingleNode("config/action[@path='/loginAction']");
//打印出type值 用attributeValue拿到值
System.out.println(action.attributeValue("type"));
}
}
案例3 获取第二个action的所有forward的path
package yzpparse;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
/**
* 获取第二个action的所有forward的path
* @author 易泽鹏
*
* 2022年6月14日上午10:19:39
*/
public class YzpDemo6 {
public static void main(String[] args) throws Exception {
// 获取第二个action的所有forward的path
InputStream in = YzpDemo6.class.getResourceAsStream("config.xml");
SAXReader sr = new SAXReader();
Document doc = sr.read(in);
// 拿到config里面的第二个action
Element actions = (Element) doc.selectSingleNode("config/action[2]");
List<Element> forwards = actions.selectNodes("forward");
for (Element forward : forwards) {
System.out.println(forward.attributeValue("path"));
}
}
}
案例4 获取第二个action里面的第2个forward的path值
package yzpparse;
import java.io.InputStream;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
/**
* 获取第二个action里面的第2个forward的path值
* @author 易泽鹏
*
* 2022年6月14日上午10:53:49
*/
public class YzpDemo7 {
public static void main(String[] args) throws Exception {
// 案例4:获取第二个action里面的第2个forward的path值
InputStream in = YzpDemo7.class.getResourceAsStream("config.xml");
SAXReader sr = new SAXReader();
Document doc = sr.read(in);
Element forwards = (Element) doc.selectSingleNode("config/action[2]/forward[2]");
System.out.println(forwards.attributeValue("path"));
}
}