JavaWeb:vue、AJax、ELement、maven、SpringBoot、、Http、Tomcat、请求响应、分层解耦

1 Vue

1.1 Vue介绍

VUE是前端框架,基于MVVM,实现数据双向绑定

框架是半基础软件,可重用的代码模型

f5aa5f91afbc4dc6821b1f8bef094523.png

1.2 Vue指令

<script src="js/vue.js"></script></head>
<body><div id="id"><!-- 绑定了一个数据模型,vue双向绑定 --><input type="text" v-model="url"><!-- v-bind绑定属性值 --><!-- v-model在表单元素创建双向数据绑定 --><a :href="url">链接1</a><a v-bind:href="url">链接2</a><!-- 插值表达式 -->{{msg}}<input type="button" value="按钮" v-on:click="handle()"><!-- 简化写法 --><input type="button" value="按钮" @click="handle()"><!-- 判定为true就渲染 --><span v-if="msg <= 30">30</span><span v-else-if="msg> 30&&msg<50">30</span><!-- 不管条件都渲染,不满足条件display隐藏 --><span v-show="msg <= 30">340</span><div v-for="ar in arr">{{ar}}</div><div v-for="(ar1,in1) in arr">{{in1}}:{{ar1}}</div></div>
</body>
<script >// 在new vue传递一个对象,el表示接管<div id="id"></div>区域new Vue({el:"#id",data:{url:"https://www.bilibili.com/",msg:20,arr:[1,2]},methods:{handle:function(){alert('hanle');}}})</script>

1.3 生命周期

156dc2d74715449d97129a4ced2d1096.png

    <div id="id"></div>
</body>
<script >// 在new vue传递一个对象,el表示接管<div id="id"></div>区域new Vue({el:"#id",data:{url:"https://www.bilibili.com/",msg:20,arr:[1,2]},mounted(){alert('vue初始化成功, HTML页面渲染成功,发送请求到服务端,加载数据')}})
</script>

326ef1a974754a199dd23d2fe5cb3c76.png

1.4 Vue-cli

 Vue-cli 是Vue官方提供的一个脚手架,用于快速生成一个 Vue 的项目模板

1 统一的目录结构

2 本地调试

3 热部署:代码变动,不需要重新运行,就可以加载最新的程序

4 单元测试

5 集成打包上线

1.5 目录结构 

be3f0020464f40d6803fe3fc0619a007.png

 1.6 前端工程化

Day03-05. 前端工程化-Vue项目_哔哩哔哩_bilibili创建vue文件

启动vue文件

3280f3ee0b54476d85d1db080f5fa832.png

vue.config.js

  //修改端口号由8080到7000devServer: {port: 7000,}

main.js

import Vue from 'vue'
//import App from './App.vue'表示要把App.vue导入当前js文件,命名为App
import App from './App.vue'
import router from './router'Vue.config.productionTip = falsenew Vue({//ES6语法,router:router两个属性名一致,可以简写为一个routerrouter,//render函数作用:将上面导入的app创建的视图创建虚拟DOM元素挂载到#app区域,这部分DOM元素是在App.vue的根组件定义的render: h => h(App)
}).$mount('#app')// 相当于一下代码
new Vue({el:"#app",router:router,render:h=>h(App)
})

1.7 制作组件文件

App.vue

<!-- 模板部分,生成html代码 -->
<template><div>{{ msg }}</div>
</template>
<!-- 控制模板的数据来源和行为 -->
<script>
//export导出一个模块,那么其他地方也可以导入
export default  {data:function(){// {}是对象,msg是数据模型return{msg:"haha"}}
}
</script>
<style>
</style>

2343f3ee46924e4e87de92a42466601e.png

2 Element

Element - 网站快速成型工具

配置Element后:

elementView.vue

<template><div><el-row><el-button>默认按钮</el-button><el-button type="primary">主要按钮</el-button><el-button type="success">成功按钮</el-button><el-button type="info">信息按钮</el-button><el-button type="warning">警告按钮</el-button><el-button type="danger">危险按钮</el-button>
</el-row></div>
</template>
<script>
export default{}</script>
<style></style>

main.js新增:

import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';Vue.use(ElementUI);

App.vue 

<template><div><element-view></element-view></div>
</template>
<!-- 控制模板的数据来源和行为 -->
<script>
import elementView from './views/element/elementView.vue';
//export导出一个模块,那么其他地方也可以导入
export default  {components:{elementView},}
</script>
<style>
</style>

ec5f11ce30cf4162a518012892d5473d.png

3 vue-router

VueRouter路由器类

router/index.js 改变:

const routes = [{path: '/',redirect:'/ele'},{path: '/ele',name: 'ele',component: () => import(/* webpackChunkName: "about" */ '../views/element/elementView.vue')}
]

elementView.vue新增: 

<template><div>
//router-link解析成a<router-link to="/ele">点我试试?</router-link>
//渲染相对应组件
<router-view></router-view>
</el-row></div>
</template>

4 ngnix

594af69ce9f340e89014389fda5e7c41.png

打包后放在dist文件夹里

将dist文件夹里面的东西放入fa8a51bb802143179b99172ebe2cd68d.png

c47efba7d02d4ce4a40c9c17e9a6b785.png 打开nginx.exe

输入http://localhost:90/

5 Ajax

5.1 作用

1 异步交互:不重新加载页面,与服务器交换数据并更新网页,比如搜索联想

2 数据交换:通过Ajax可以给服务器发送请求,并获取数据

5.2 原生Ajax

<body><input type="button" value="获取数据" onclick="getData()"><div id="div1"></div></body><script>function getData(){//1. 创建XMLHttpRequest var xmlHttpRequest  = new XMLHttpRequest();//2. 发送异步请求xmlHttpRequest.open('GET','http://yapi.smart-xwork.cn/mock/169327/emp/list');xmlHttpRequest.send();//发送请求//3. 获取服务响应数据xmlHttpRequest.onreadystatechange = function(){if(xmlHttpRequest.readyState == 4 && xmlHttpRequest.status == 200){//获取响应的数据,然后放到div1这个区域中document.getElementById('div1').innerHTML = xmlHttpRequest.responseText;}}}
</script>

5.3 Axios

对原生Ajax进行封装

Axios中文文档 | Axios中文网 (axios-http.cn)

<body><input type="button" value="获取数据" onclick="get()"><input type="button" value="提交数据" onclick="post()"><script>function get(){// 通过axios发送异步请求getaxios({method: "get",
// 传递数据可以在url后面"?key=word"url: "https://yapi.pro/mock/293482/User/id"
//想获取服务器端相应回来的数据,用成功回调函数then((result) =>xxx
}).then((result) => {console.log(result.data);
});// 简化版本
// axios.get("http://yapi.smart-xwork.cn/mock/169327/emp/list").then((result) => {
//     console.log(result.data);
// });}function post(){axios({method: "post",url: "https://yapi.pro/mock/293482/User/id",data: "height=199"
}).then((result) => {console.log(result.data);
});// 简化版本
// axios.post( "http://yapi.smart-xwork.cn/mock/169327/emp/deleteById","id=1").then((result) => {
//     console.log(result.data);
// });}</script>
</body>

点击获取数据:

370f0e8792f24ef38662ec2f6b5a8947.png

api接口文档管理平台Yapi

YApi Pro-高效、易用、功能强大的可视化接口管理平台

作用:1 api接口管理 2Mock:模拟真实接口,生成模拟测试数据

创建了我的api:
8dee7bbde89846db995686426e2cc3f2.png

6 Maven

6.1 介绍

1 依赖管理,管理jar包

2 统一结构,不同编译器生成的结构可能不同

3 自动化项目构建,根据指令快速完成清理、编译、测试、打包、发布

2b47838aa34546699ba0c0ca128a2216.png

不同阶段有不同文件产生,编译时有编译字节码文件,打包有jar文件 

70cb8c2fbd204ffe9c4b3beec1aba8fa.png

项目对象模型POM,或者称为坐标

6e9ec2aa63934cd185ba49c979a5f9d1.png

d9a6617560ed4d9e8bba9c8677f3de92.png

 依赖管理模型

6.2 依赖管理

6.2.1 创建依赖

Maven Repository: Search/Browse/Explore (mvnrepository.com)

pom.xml

<dependencies><dependency>
//依赖ch.qos.logback下的logback-classic<groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.3</version></dependency></dependencies>

6.2.2 依赖传递

9d231441accb49e2941003850b1f7a88.png

查看依赖关系 

c7c20e331c784ed5a63cc8cb9b88678d.png

解除依赖:

<dependencies><dependency><exclusions><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId></exclusions></dependency></dependencies>

 6.2.3 依赖范围

513697b5b27148ef93cdb5ed6bec5b53.png

<dependencies><dependency>
//依赖ch.qos.logback下的logback-classic<groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.3</version><scope>test</scope></dependency></dependencies>

6.2.3 生命阶段

050fb392ae7f4f0c99b9d3a94a7b3229.png

7 SpringBoot 

创建一个SpringBoot工程

2d538b4296354a4685dea7d0522044ed.png

HelloController
//请求处理类
@RestController
public class HelloController {//访问/hello会使用以下方法@RequestMapping("/hello")public String Hello(){System.out.println("hello1");return "hello";}
}

运行Springbootdemo1Application

f7da921d36e04a52bc26cfe7ca35751f.png

ea1d5813ac224c4abed91a11cc287b3a.png

成功!

8 HTTP协议

 Hyper Text Transfer Protocol,超文本传输协议,规定了浏览器和服务器之间数据传输的规则。

HTTP协议是无状态的协议:每次请求-响应都是独立的

1aa1e84689644a8eb209c97b13bf72cb.png

11fe05bd604b439288ef9175121f7ec8.png HTTP响应格式ca16bf7bf6d74a02b61dfd578afcd610.png

Web服务器是一个软件程序,对HTTP协议的操作进行封装 

9 Tomcat

Tomcat(Web容器、Servlet容器)是轻量级Web服务器,支持Servlet/JSP少量JavaEE规
JavaEE:Java企业版
Servlet程序需要依赖于 Tomcat才能运行
72653b4f4abb4956802aa66e87e8e2dc.png

解决乱码:tomcat文件夹 

91d7770bac9f4ccb8b89062650a74e38.png

bf8dea50277f4e1eacdd32cf357df32d.png 解决占用端口

f834e013547942cf8fce1dbab7bcec6e.png

 cmd

netstat -ano | findstr 8080 
taskkill -pid LISTENING占用的pid的数字 -f

53df8a9b71a94863b73bd7cf2e48890b.png

 HTTP协议默认端口号为80,如果将Tomcat端口号改为80,则将来访问Tomcat时,将不用输入端口号

改端口号

588aa0e3ddb64385bcc5f40d2e4a2136.png

39ee496820054fe8aeb89f1a916b71c7.png

Tomcat 部署项目:将项目放置到 webapps 目录下
访问方法:localhost:8080/文件夹中的html文件

起步依赖:

1.spring-boot-starter-web:包含了web应用开发所需要的常见依赖

2.spring-boot-starter-test:包含了单元测试所需要的常见依赖

不需要加version,因为在<parent>父工程定义好了

https://docs.spring.io/spring-boot/docs/2.7.4/reference/htmlsingle/#using.build-systems.starters

 基于Springboot开发的web应用程序,内置了tomcat服务器,当启动类运行时,会自动启动内嵌的tomcat服务器

10 请求响应

10.1 请求HttpServletRequest

@RestController
public class simpleParam {@RequestMapping("/simpleParam")public String param(HttpServletRequest request){String name=request.getParameter("name");String  ageStr=request.getParameter("age");int age=Integer.parseInt(ageStr);System.out.println(name+"---"+age);return "ok";}
}

postman:

2fd2c4eb213f46d0921ce382e1904b3c.png

10.2 获取实体参数

原始程序获取参数:

@RestController
public class simpleParam {@RequestMapping("/simpleParam")public String param(HttpServletRequest request){String name=request.getParameter("name");String  ageStr=request.getParameter("age");int age=Integer.parseInt(ageStr);System.out.println(name+"---"+age);return "ok";}
}

3f6a73d703f34c809742109d6dc46e0e.png

基于springboot方法:

@RestController
public class simpleParam {@RequestMapping("/simpleParam")public String param(String name,Integer age){System.out.println(name+"---"+age);return "ok";}
}
    @RequestMapping("/simpleParam")
//    方法形参与请求参数名不一致,可以用@RequestParam映射public String param(@RequestParam(name="name")String username, Integer age){System.out.println(username+"---"+age);return "ok";

Dog.java

public class Dog {private String name;private String age;// ptg生成
xx
}

User.java

public class user {private String name;private Integer age;private Dog do1;
ptg}
simpleParam
    @RequestMapping("/simplepolo")public String param(user u){System.out.println(u);return "ook";}

 96a058f4b4d84801b2a25aec760dd552.png

10.3 数组集合参数

 @RequestMapping("/arrayParam")public String param(String[] arr){System.out.println(Arrays.toString(arr));return "ook";}

f9b27c26f6c949b78e73f2fd1e2bc724.png

e6971ee337144584b3115bfe6dbc28dc.png

集合参数 

   @RequestMapping("/listParam")public String param(@RequestParam List<String> arr){System.out.println(arr);return "ook";}

10.4 日期参数

    @RequestMapping("/dataParam")
//    pattern与value必须一致,ldt必须与名字保持一致public String param(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") LocalDateTime ldt){System.out.println(ldt);return "ook";}

4c828b94b99e4ad8b5b0a57ef315da38.png

10.5 json参数

   @RequestMapping("/jsonParam")public String param(@RequestBody user u){System.out.println(u);return "ook";}

14e451e03eb6482daf14dc8c7ae2341e.png

c3829b7c1178442b985abc9798d6b27e.png

10.6 路径参数

    @RequestMapping("/path/{id}/{name}")public String param(@PathVariable Integer id,@PathVariable String name){System.out.println(id+name);return "ook";}

5d570e312c364cb8bb58bf83221523aa.png

10.7响应HttpServletResponse

@RestController = @Controller + @ResponseBody
@ResponseBody:将方法返回值直接响应,如果返回值类型是 实体对象/集合 ,将会转换为JSON格式响应
统一响应结果:用一个类节省返回值的编写
/*** 统一响应结果封装类*/
public class Result {private Integer code ;//1 成功 , 0 失败private String msg; //提示信息private Object data; //数据 datapublic Result() {}public Result(Integer code, String msg, Object data) {this.code = code;this.msg = msg;this.data = data;}public Integer getCode() {return code;}public void setCode(Integer code) {this.code = code;}public String getMsg() {return msg;}public void setMsg(String msg) {this.msg = msg;}public Object getData() {return data;}public void setData(Object data) {this.data = data;}public static Result success(Object data){return new Result(1, "success", data);}public static Result success(){return new Result(1, "success", null);}public static Result error(String msg){return new Result(0, msg, null);}@Overridepublic String toString() {return "Result{" +"code=" + code +", msg='" + msg + '\'' +", data=" + data +'}';}
}

应用:

    @RequestMapping("/path/{id}/{name}")public Result param(@PathVariable Integer id, @PathVariable String name){System.out.println(id+name);return Result.success("ook");}

 7a8619c35b9c45eea3d0f36557d3ce39.png

10.8 案例

获取员工数据,返回统一响应结果,在页面渲染展示

3ed006c6ec1f4cfcbee00f8e8949b0f3.png

引入数据:

EmpController
@RestController
public class EmpController {@RequestMapping("/listEmp")//@RequestBody处理将返回对象变为jsonpublic Result  list(){
//        1.加载并解析emp.xml//拿到文件路径String file=this.getClass().getClassLoader().getResource("emp.xml").getFile();
//        解析的file文件,往emp对象封装,解析出list集合List<Emp> emplist= XmlParserUtils.parse(file, Emp.class);
//        2.对数据进行转换处理//基于stream流遍历emplist.stream().forEach(emp->{String gender=emp.getGender();if("1".equals(gender)){emp.setGender("男");}else if("2".equals(gender)){emp.setGender("女");}});return Result.success(emplist);}}

bfa4776a422c4d0295b6efccc4420d47.png

优化:分层解耦 

6a952b9550b94171b36de3210101e247.png

controller层:获取(调用service层)、返回数据

@RestController
public class EmpController {//高耦合
//    private EmpService empService=new EmpServiceA();@Autowiredprivate EmpService empService;@RequestMapping("/listEmp")//@RequestBody处理将返回对象变为jsonpublic Result  list(){List<Emp> emplist=empService.listEmp();return Result.success(emplist);}
}

service层:业务逻辑处理:将gender的1变为男,2变为女

EmpService.interface

public interface EmpService {
//    获取员工列表public List<Emp> listEmp();
}
EmpServiceA.java
//@Component表示交给IOC容器管理,称为IOC容器的bean
@Component
public class EmpServiceA implements EmpService {//高耦合// private EmpDao empDao=new EmpDaoA();//依赖注入,IOC容器会提供该类型bean对象,并赋值给该变量
@Autowiredprivate EmpDao empDao;List<Emp> emplist=empDao.listemp();@Overridepublic List<Emp> listEmp() {//        2.对数据进行转换处理//基于stream流遍历emplist.stream().forEach(emp->{String gender=emp.getGender();if("1".equals(gender)){emp.setGender("男");}else if("2".equals(gender)){emp.setGender("女");}});return emplist;}
}

Dao层:加载并解析emp.xml

EmpDao

public interface EmpDao {
//    获取员工列表public List<Emp> listemp();
}
EmpDaoA
//@Component表示交给IOC容器管理,称为IOC容器的bean
@Component
public class EmpDaoA implements EmpDao {@Overridepublic List<Emp> listemp() {//1.加载并解析emp.xml//拿到文件路径String file=this.getClass().getClassLoader().getResource("emp.xml").getFile();
//        解析的file文件,往emp对象封装,解析出list集合List<Emp> emplist= XmlParserUtils.parse(file, Emp.class);return emplist;}
}

11 分层解耦 

controller:控制层,接收前端发送的请求,对请求进行处理,并响应数据。

service:业务逻辑层,处理具体的业务逻辑。

dao:数据访问层(Data Access Object)(持久层),负责数据访问操作,包括数据的增、删、改、查

dao接口:dao层处理的数据有很多,为了灵活切换各种实现

高内聚:service层仅存放与员工有关的业务逻辑处理

低耦合:降低层与层的关联

使用以上四个注解都可以声明bean,但是在springboot集成web开发中,声明控制器bean只能用@Controller

@ComponentScan注解虽然没有显式配置,但是实际上已经包含在了启动类声明注解 @SpringBootApplication 中,默认扫描的范围是启动类所在包及其子包。

如果dao包不和controller在同一个文件夹,那么在启动页可以用:@ComponentScan("dao","所在包名")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/751922.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Custom GPTs Are Here and Will Impact Everything AI

定制GPT时代来临&#xff0c;将深刻影响人工智能领域 摘要 OpenAI最新推出的定制GPT标志着个性化数字助手的全新纪元&#xff0c;将ChatGPT的强大能力应用于满足个人和专业的需求。本文将探讨定制GPT的核心特点、应用场景、安全性保障以及其对人工智能未来的影响。 定制GPT的…

Keras库搭建神经网络

Keras并非简单的神经网络库&#xff0c;而是一个基于Theano的强大的深度学习库&#xff0c;利用它不仅仅可以搭建普通的神经网络&#xff0c;还可以搭建各种深度学习模型&#xff0c;如自编码器、循环神经网络、递归神经网络、卷积神经网络等。 安装代码&#xff1a; pip ins…

Docker Mysql无root账户创建最高权限用户

创建最高权限用户 进入 MySQL 容器的命令行界面。您可以使用以下命令&#xff1a; 修改配置文件my.cnf 无密码进入 [mysqld]下输入 skip-grant-tables重启mysql容器 进入容器内部 container_name 容器ID或name docker restart mysql docker exec -it <container_name>…

Kubectl常用命令

管理资源&#xff08;查看、创建、更新、删除&#xff09; 查看node资源 kubectl get nodes查看命名空间 kubectl get ns查看service资源 -n 指明所属的命名空间&#xff0c;不写默认看命名空间为default下的所有service kubectl get svc -n default查看pod资源 -n 指明所…

fpga_图像处理

一 fpga图像处理的基本原理 fpga图像处理的基本原理是将图像数据转换为数字信号&#xff0c;并通过fpga实现各种图像处理算法和技术。图像数据可以通过各种传感器和摄像头获得&#xff0c;然后通过模数转换器(ADC)将其转换为数字信号&#xff0c;数字信息可以通过fpga的输入输出…

tcpudp面试题

什么是IP地址 ip地址是主机在网络中的唯一标识&#xff0c;当主机更换网络时ip号会改变。 ip网络号主机号&#xff08;A类网、B类网、C类网、D类网、E类网&#xff09;tcp和udp的区别 tcp&#xff1a; 1、提供面向链接的&#xff0c;可靠的数据传输服务&#xff0c; 2、稳定&am…

线性代数笔记20--特征值特征向量与旋转矩阵推导

1. 特征向量与特征值 研究对象是一个平面 A A A&#xff0c;向量 X X X通过 A A A变换后仍然平行于 X X X。 这样的向量就叫特征向量。 变换后的向量与原向量的比值就是特征值。 A X / / X A X λ X AX \mathop{//} X\\ AX \lambda X AX//XAXλX 如果矩阵 A A A是奇异矩阵&…

【计算机网络】基本概念

基本概念 IP 地址端口号协议协议分层封装分用客户端服务器请求和响应两台主机之间的网络通信流程 IP 地址 概念&#xff1a;IP 地址主要是用于唯一标识网络主机、其他网络设备&#xff08;如路由器&#xff09;的网络地址。简单来说&#xff0c;IP地址用来唯一定位主机。格式&…

网络安全之DDos攻击原理与防御

DDos简介 对于DDos(分布式拒绝服务)攻击&#xff0c;人们往往谈虎色变。它被认为是安全领域中最难解决的问题之一&#xff0c;迄今为止也没有完美的解决方案。DDos攻击是一种网络攻击方式&#xff0c;其目的是通过利用大量的互联网连接设备同时向目标网站或服务发送大量请求&a…

软件架构设计 C/S与B/S架构的区别

一、什么是C/S架构&#xff1f; C/S是Client/Server的缩写。服务器通常采用高性能的PC、工作站或小型机&#xff0c;并采用大型数据库系统&#xff0c;如Oracle或SQLServer。 C/S架构软件有一个特点&#xff0c;就是如果用户要使用的话&#xff0c;需要下载一个客户端&#x…

uni-popup(实现自定义弹窗提示、交互)

一般提示框的样式&#xff0c;一般由设计稿而定&#xff0c;如果用uniapp的showmodel&#xff0c;那个并不能满足我们需要的自定义样式&#xff0c;所以最好的方式是我们自己封装一个&#xff01;&#xff08;想什么样就什么样&#xff09;&#xff01; 一、页面效果 二、使用…

SpringMVC03 基础操作续与几个简单的交互

前文 第一篇 第二篇 基础操作 上篇博客我们知道了如何获取Session内容以及传输数组,json,对象,集合等的传送和获取 这节课我们可以从上篇的结束开始,其实Spring对Session进行了进一步的封装,我们可以使用其他的方式也可以读取和设置Session(更简洁的方式) 1.直接使用HTTPSessio…

ssh命令——安全远程连接服务

ssh命令是Secure Shell的简写&#xff0c;其功能是安全地远程连接服务器&#xff0c;ssh是OpenSSH套件中的客户端连接工具&#xff0c;通过SSH加密协议进行远程主机访问&#xff0c;并对远程服务器进行管理。 ssh命令的基本语法格式如下&#xff1a; ssh [选项] 主机名或IP地…

[春招面试题] 当有多个环境特定的配置文件时,Spring Boot会如何处理属性值的覆盖?

当有多个环境特定的配置文件时&#xff0c;Spring Boot通过一种被称为“profile-specific”的属性覆盖机制来处理这些配置文件。 简单来说&#xff0c;Spring Boot首先加载默认配置文件&#xff08;即application.properties或application.yml&#xff09;&#xff0c;然后加载…

【GPT-SOVITS-02】GPT模块解析

说明&#xff1a;该系列文章从本人知乎账号迁入&#xff0c;主要原因是知乎图片附件过于模糊。 知乎专栏地址&#xff1a; 语音生成专栏 系列文章地址&#xff1a; 【GPT-SOVITS-01】源码梳理 【GPT-SOVITS-02】GPT模块解析 【GPT-SOVITS-03】SOVITS 模块-生成模型解析 【G…

文件包含漏洞(input、filter、zip)

一、PHP://INPUT php://input可以访问请求的原始数据的只读流&#xff0c;将post请求的数据当作php代码执行。当传入的参数作为文件名打开时&#xff0c;可以将参数设为php://input,同时post想设置的文件内容&#xff0c;php执行时会将post内容当作文件内容。从而导致任意代码…

体系结构安全第二次作业:调研整理编译器优化引入的安全问题,形成调研报告提交

一、背景 今天&#xff0c;复杂而泛在的软件架构支撑着全球经济&#xff0c;编译器和高级语言正是这些软件的基石。强大而优雅的编译技术在硬件综合等领域同样有着“连城”的价值。毫不夸张地说&#xff0c;与半导体技术一样&#xff0c;编译器和高级语言处于信息时代的核心地位…

wireshark解析https数据包

Debian11环境&#xff1a; 在linux环境下抓取访问某个https的网址时抓取的数据包都是加密的&#xff0c;导致无法跟踪到数据包流&#xff0c;现在尝试将抓取的https包进行解密。 1、解密https数据包需要设置SSLKEYLOGFILE变量&#xff0c;推荐写入配置文件中。 echo "exp…

使用IDEA进行Scala编程相关安装步骤

一、相关安装包&#xff08;jdk最好用1.8版本&#xff0c;其他不做要求&#xff09; IDEA安装包 jdk-8u101-windows-x64.exe scala-2.12.19 二、安装顺序 在安装IDEA之前&#xff0c;首先要安装好java和scala环境&#xff0c;以便后续配置 三、jdk和scala安装要求 1.jdk安…

【启动npm run serve 奇怪的报错】

报错如下&#xff1a; INFO Starting development server... utils.js:587Uncaught TypeError [ERR_INVALID_ARG_VALUE]: The argument path must be a string or Uint8Array without null bytes. Received E:\\#\u0000#idea-workspace\\wonderful-search\\wonderful-search-v…