Web学习笔记

Web学习笔记

  • flask库
  • 前端基础
        • 超链接:
        • 空连接:
        • 图片:
        • 视频(音频):
        • 嵌套使用
        • 列表
        • 表格
        • 格式化表格
        • input表单系列
  • 网络请求
        • GET方式
        • POST请求
        • 通过GET方式获取输入参数
        • 通过POST方式获取输入参数
        • 注册页面
  • CSS
      • 三种使用方式
        • 行内式
        • 外联式
        • 内嵌式
      • 选择器
        • 1、类选择器
        • 2、id选择器
        • 3、标签选择器
        • 4、通配符选择器
        • 5、属性选择器
        • 6、后代选择器
      • CSS样式
        • 高度与宽度
        • 字体和颜色
  • MySQL基础
    • SQL语言
        • SQL分类
      • DDL
      • DML
      • DQL
      • 约束
    • 事务
  • JDBC
  • JavaSvript
    • 基础语法
    • BOM对象
    • DOM
    • 事件监听
  • HTTP
    • HTTP请求数据格式
    • HTTP响应数据格式
  • Tomcat
    • Maven Web项目
  • Servlet
    • request
    • response

flask库

基本使用方法:python与前端交互

from flask import Flask, render_template, requestapp = Flask(__name__, template_folder="templates")# 用户在浏览器访问/chat时自动执行 index() 函数。
@app.route("/chat")
def index():# return "中国联通!"# 将html文件放在templates文件夹下return render_template("./open1.html") @app.route("/chat")
def index2():return render_template("./open2.html")  if __name__ == "__main__":app.run(port=8000)  # 自定义端口号(默认5000)

前端基础

<h1>一级标签</h1>
<h2>二级标签</h2>
<div>块级标签(占一行)</div>
<span>行内标签(不独立占行)</span><b>文本加粗</b>
<strong>文本加粗</strong><u>下划线</u>
<ins>下划线</ins><i>倾斜</i>
<em>倾斜</em><s>删除线</s>
<del>删除线</del><!-- hr水平分割线 br换行符 p段落 -->
<hr>
<br><!-- 空格 -->
我要&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;学习<!-- 行内式CSS -->
<div>/* 注释 */<span style="color: red;">时间</span><span>2020.10.10</span>
</div>
超链接:

target="_blank"在新窗口打开标签,默认是覆盖原网页

<a href="https://www.baidu.com/" target="_blank">百度</a>
空连接:
<a href="#">空链接</a>
图片:

也可以设置width=10% 这种。

<img src="R.jpg" alt="加载失败的替换文本" title="鼠标悬停时的提示文字" width="400">
视频(音频):

controls表示显示播放的控件,autoplay自动播放(部分浏览器不支持),loop循环播放

<audio src="时间的尽头.mp3" controls autoplay loop></audio>
嵌套使用

点击图片即可跳转到链接

<a href="https://www.baidu.com/" target="_blank"><img src="../baidu.png" alt="百度一下" width="300px">
</a>
列表

无序列表

<ul><li>榴莲</li><li>香蕉</li><li>苹果</li>
</ul>

有序列表

<ol><li>张三</li><li>李四</li><li>王五</li>
</ol>

自定义列表

<dl><dt>主题1</dt><dd>项目1</dd><dd>项目2</dd><dt>主题2</dt><dd>项目1</dd><dd>项目2</dd>
</dl>
表格
<table border="1" width="300" height="100"><caption><strong>学生成绩单</strong></caption><tr> <!-- tr表示行 --><th>姓名</th>   <!-- th表示表头单元格 --><th>成绩</th><th>评语</th></tr><tr><td>司马懿</td>  <!-- tr表示普通单元格 --><td>90</td><td>真棒</td></tr><tr><td>诸葛亮</td><td>100</td><td>非常棒</td></tr>
</table>
格式化表格
<table border="1" width="300" height="100"><caption><strong>学生成绩单</strong></caption><thead><tr> <!-- tr表示行 --><th>姓名</th>   <!-- th表示表头单元格 --><th>成绩</th><th>评语</th></tr></thead><tbody><tr><td>司马懿</td>  <!-- tr表示普通单元格 --><td rowspan="2">90</td><!-- rowspan跨行合并 --><td>真棒</td></tr><tr><td>诸葛亮</td><td>非常棒</td></tr></tbody><tfoot><tr><td colspan="3">总结</td><!-- colspan跨列合并 --></tr></tfoot>
</table>
input表单系列
  • 具有重置提交按钮的输入框
<form method="post" action="提交地址"><input type="text" placeholder="输入用户名"><br><input type="password" placeholder="请输入密码"><br><input type="reset"><input type="submit">
</form>
  • 单选框
    checked 表示默认选中
性别:
<input type="radio" name="gender"><input type="radio" name="gender" checked><br>
  • 多选框
爱好:<input type="checkbox" name="hobby">游泳<input type="checkbox" name="hobby">读书<input type="checkbox" name="hobby">跑步
  • 下拉菜单

multiple表示多选

<select name="city" multiple><option>北京</option><option>上海</option><option selected>深圳</option><option>广州</option>
</select>
  • 文件选择
选择文件:<input type="file"><br>
选择多个文件:<input type="file" multiple>
  • 多行文本框
<textarea name="more" cols="30" rows="3"></textarea>

网络请求

GET方式

将请求数据拼接到url中。请求数据作为参数在url中。

POST请求

请求数据在请求头和请求体中。

通过GET方式获取输入参数
from flask import Flask, render_template, requestapp = Flask(__name__, template_folder="templates")# 用户在浏览器访问/chat时自动执行 index() 函数。
@app.route("/get/register", methods=["GET"])
def index1():# 将html文件放在templates文件夹下return render_template("./open.html")  @app.route("/get/result", methods=["GET"])
def index2():# 获得用户输入信息print(request.args)return "注册成功!"if __name__ == "__main__":app.run(port=8000)  # 自定义端口号(默认5000)
通过POST方式获取输入参数
from flask import Flask, render_template, requestapp = Flask(__name__, template_folder="templates")# 用户在浏览器访问/chat时自动执行 index() 函数。
@app.route("/register", methods=['get', 'post'])
def index1():# 将html文件放在templates文件夹下return render_template("./open.html")  @app.route("/post/result", methods=["post"])
def index3():# 获得用户输入信息print(request.form)user = request.form.get("user")pwd = request.form.get("pwd")# getlist获取多标签return "注册成功!"if __name__ == "__main__":app.run(port=8000)  # 自定义端口号(默认5000)
注册页面

./open.html文件

method=是请求方式,action=返回地址。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>登录界面</title>
</head>
<body><form method="post" action="/post/result">用户名<input type="text" name="user" placeholder="输入用户名"><br>密码<input type="password" name="pwd" placeholder="输入密码"><br><input type="submit"><input type="reset"></form>
</body>
</html>

简化版本
python

from flask import Flask, render_template, requestapp = Flask(__name__, template_folder="templates")# 用户在浏览器访问/chat时自动执行 index() 函数。
@app.route("/register", methods=['get', 'post'])
def register():# 将html文件放在templates文件夹下return render_template("./open.html")  @app.route("/result", methods=['get', 'post'])
def do_register():# 判断html文件的请求参数的获取方式if request.method == "get":print(request.args)print("get方式")print("注册成功!")else:# post方式获得用户输入信息print(request.form)user = request.form.get("user")pwd = request.form.get("pwd")print("post方式")return "注册成功!"if __name__ == "__main__":app.run(port=8000)  # 自定义端口号(默认5000)

html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>登录界面</title>
</head>
<body><!-- --><form method="post" action="/result">用户名<input type="text" name="user" placeholder="输入用户名"><br>密码<input type="password" name="pwd" placeholder="输入密码"><br><input type="submit"><input type="reset"></form>
</body>
</html>

CSS

三种使用方式

行内式
<p style="color: red;background-color: darkgreen;">这是一段文字</p>
外联式
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><!-- 外联语句 --><link rel="stylesheet" href="./my.css">
</head>
<body><p class="x">外联式使用CSS</p>
</body>
</html>

my.css文档

.x{color: brown; font-size: 30px;background-color:gold;width: 250px;height: 50px;
}
内嵌式
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>/*内嵌式CSS*/.x{color: brown; font-size: 30px;background-color:gold;width: 250px;height: 50px;}</style>
</head>
<body><p class="x">这是HTML文件</p>这是HTML文件
</body>
</html>

选择器

1、类选择器

如果同时使用两个类选择器,并且有格式冲突,那么默认选择style中位置靠后的格式,如果不想被覆盖,可以在前面的某个格式属性中加入!important作为标注,如:color:red !important;

<head><style>/*定义CSS类,以.开头*/.red{color: crimson;}.size{font-size: 66px;}</style>
</head>
<body><!-- 使用CSS类 --><p class="red size">222</p></body>
2、id选择器
<head><style>#a{color: chartreuse;}</style>
</head>
<body><!-- 但一个id只能使用一次,一般配合JS使用 --><p id="a">一段文字</p>
</body>
3、标签选择器
<head><style>p{color: chartreuse;}</style>
</head>
<body><!-- 所有的p标签都会被使用 --><p>一段文字</p>
</body>
4、通配符选择器
<head><style>/*所有标签的都会被渲染,一般用于处理文字格式*/*{color: blueviolet;padding: 0;margin: 0;}</style>
</head>
<body><p>先改年号</p><div>你好</div><span>我好</span>
</body>
5、属性选择器
<style>input[type="text"]{border: 1px solid red;}
</style><!-- text输入框会有红色边框 -->
<input type="text">
<input type="password">

或者如下:

<style>.v1[xx="123"]{color: gold;}
</style><!-- 第一行文字变成金色 -->
<div class="v1" xx="123">s</div>
<div class="v1" xx="456">s</div>
<div class="v1" xx="789">s</div>
6、后代选择器
<style>/* 如果写成.yy > li 则只会查找子代标签,不会查找孙代标签 */.yy li{color: red;}
</style><div class="yy"><ul><li>美国</li><li>日本</li><li>韩国</li></ul>
</div>

CSS样式

高度与宽度
.c{height: 300px;width: 50%;
}

备注:

  • 宽度支持百分比,高度不支持。
  • 行内标签默认无效,块级标签会占用一整行。
  • 可以通过 display:inline-block;修改。(兼具行内与块级标签的优势)。
字体和颜色

颜色、大小、加粗、字体

.c{color: #00FF7F;font-size: 58px;font-weight: bolder;font-family: 'Times New Roman', Times, serif;border: 1px solid red; /*边框*/text-align: center;    /*水平方向居中*/line-height: 59px;     /*垂直方向居中,跟方框大小相关*/
}

块级标签的浮动

.c{/* 标签浮动 */float: left;height: 100px;width: 100px;border: 1px solid red;
}<div><div class="c"></div><div class="c"></div><div class="c"></div><!-- 将浮动的标签拽回 --><div style="clear: both;"></div>
</div>
设置div的边距(内边距) ```css .c{ padding-top:20px; padding-left:20px; padding:20px; /*上下左右都设置*/ padding: 20px 10px 5px 20px; /*上右下左*/ } ``` 外边距(离其他div块的距离) ```css .c{ margin-top:20px; } ``` 区域居中 ```css margin: 2px auto; /*上边两个像素,左右自动居中*/ ```

MySQL基础

下载:https://downloads.mysql.com/archives/community/

启动关闭:

启动:net start mysql
关闭:net stop mysql

登陆:mysql -uroot -p
退出:exit

登陆参数:

mysql -u用户名 -h服务器地址(默认127.0.0.1) -P端口号(默认3306)

卸载:

net stop mysql
mysqld -remove mysql
删除相关目录和环境变量

SQL语言

show databases; -- 分号结尾,不区分大小写
-- 单行注释
# mysql特有单行注释
/*多行注释*/
SQL分类
  • DDL:数据定义语言,操作数据库和表
  • DML:数据操作语言:对数据增删改
  • DQL:数据查询语言:对数据查询
  • DCL:数据控制语言:定义数据库的访问权限和安全级别,以及创建用户。

DDL

创建数据库

create database db1;
create database if not exists db1;

删除数据库

drop database db2;
drop database if exists db2;

使用数据库

use db1;
-- 查看当前使用的数据库
select database();

创建表Create

show tables; -- 查询表
desc da1;    -- 查询表结构create table tb_user( -- tb_user是表名id int,           -- id 表头,数据类型为intusername varchar(20), -- 最大20位字符串(变长)password varchar(20), 
);

      tb_user

idusernamepassword

删除表

drop table if exists tb_user;

修改表

-- 修改表名
alter table 表名 rename to 新表名;
-- 添加列
alter table 表名 add 列名 数据类型;
-- 修改数据类型
alter table 表名 modify 列名 新数据类型;
-- 修改列名与数据类型
alter table 表名 change 列名 新列名 新数据类型;
-- 删除列
alter table 表名 drop 列名;

DML

添加数据

  1. 指定列添加数据(列与值一一对应)
insert into 表名(列名1,列名2...) values(1,值2...);
  1. 全部列添加数据(需要与表头数量相等)
insert into 表名 values(1,值2...);
  1. 批量添加数据
insert into 表名(列名1,列名2...) values(1,值2...),(1,值2...),(1,值2...),...;
insert into 表名 values(1,值2...),(1,值2...),(1,值2...),...;

修改数据
如果没有写条件会改变所有记录

-- 格式:updata 表名 set 列名1=值1,列名2=值2,...[where 条件];
update stu set sex = '女' where name = '张三';

删除数据

delete from 表名 while 条件;

DQL

单表查询

select 列名1,列名2... from 表名;-- 去除重复结果
select distinct 列名1,列名2... from 表名;-- 起别名
select name as 姓名,sex as 性别, ... from 表名;

条件查询

select * from 表名 while 条件;

模糊查询

select * from 表名 while name like '_化%'; -- like关键字,_匹配一个字符,%匹配多个字符

排序查询

select 列表字段 from 表名 order by 排序字段名1[排序方式],排序字段名2[排序方式],...;

排序方式

  • asc 升序(默认)
  • desc降序

聚合函数:将一列作为整体纵向计算。

  • count(列名) 统计数量
  • sum(列名) 求和
  • max(列名) 最大值
  • min(列名) 最小值
  • avg(列名) 平均值
select count(id) from stu;  -- 统计id数量

分页查询(limit是MySQL的方言)

select 字段列表 from limit 起始索引,查询条目数;

起始索引 = (当前页码-1)*每页条目数

约束

  • 主键约束:primary key
  • 非空约束:not null
  • 唯一约束:unique
  • 检查约束:check
  • 默认约束:default (未填写数据时使用默认数据)
create table emp(id int primary key,name varchar(10) not null unique,salary double(7,2) default 0
);

事务

一组数据库操作命令,要么同时失败要么同时成功(绑定)

-- 开启事务
begin;
-- 提交事务(操作成功时提交)
commit;
-- 回滚事务(回到事务开启之前的操作)
rollback;

JDBC

使用java操作数据库(Java DataBase Connectivity)
首先在创建工程之后应该导入驱动包。
框架

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;public class JDBCDemo {public static void main(String[] args) throws Exception {//注册驱动Class.forName("com.mysql.jdbc.Driver");//获取连接String url = "jdbc:mysql://127.0.0.1:3306/db1";String username = "root";String password = "012811";Connection conn = DriverManager.getConnection(url, username, password);//定义sql语句String sql = "update account set money = 2000 whrer id = 1";//获取sql的对象statementStatement stmt = conn.createStatement();//执行sql语句,返回修改行数int count = stmt.executeUpdate(sql);//释放资源stmt.close();conn.close();}
}

ctrl+alt+T快捷键:生成嵌套语句

通过事务方式执行sql语句:

try {//开启事务conn.setAutoCommit(false);//执行语句int count1 = stmt.executeUpdate(sql1);int count2 = stmt.executeUpdate(sql1);//提交事务conn.commit();
} catch (Exception e) {//回滚事务conn.rollback();
}

Statement作用:执行sql语句。

int num = stmt.executeUpdate(sql);//执行DML、DDL语句(返回修改行数)
ResultSet result = executeQuery(sql);//执行DQL语句,(返回查询结果集)

whlie(result.next()){int id = result.getInt(1);//可以通过下标签获取数据(默认从1开始)String name = result.getString("name");//可以通过列名获取数据
}
result.close();

JavaSvript

基础语法

引入方式

<script>alert("你好!");//内部方式
</script>//外部方式
<script src="./demo.js"></script>

基础语法

  1. 区分大小写
  2. 结尾有;
  3. 注释:单行注释//,多行注释/**/
  4. 大括号表示代码块
  5. 输出语句:

    window.alert()//写入警告框
    document.write()//写入HTML输出
    console.log()//写入浏览器控制台

  6. 变量
    var num = 123;
    num = "nihao";
    //var关键字定义的变量相当于全局变量,并可以重复定义
    {let num = 2; //相对于局部变量
    }count num1 = 10; //常量,定义后不可修改
    
  7. 数据类型

    number:数字(整数,小数,NaN)
    string:字符,字符串,单双引号均可以
    boolean:布尔
    null:空对象
    undefined:申明的变量未初始化
    可以使用typeof获取数据类型,如alert(typeof num);

  8. 运算符

    == :判断值是否相等,如20=="20"返回true。
    === :判断是否完全等于。

  9. 类型转换】

    字符串转number,前面加个+号,不能转为数字则转为NaN;
    var num = +“20”;
    或者使用parseInt(),如parseInt(str);

    var flag=3;
    if(flag){alert("转为ture");  
    }else{alert("转为false");  
    }
    

    字符串转布尔:空字符串转为false
    数字转为布尔:NaN和0转为false
    null 和 undefined 转为 false

  10. 流程控制语句:跟java相同:if…else   swith…case   while   do…while   for
  11. 函数
    function add(a,b){ //function关键字return a+b;
    }let result = add(1,2);  //调用
    
  12. 数组 var arr = [1,2,3]; 或者var arr = new Array(1,2,3); 长度和类型不固定。

    获取长度 arr.lrngth
    添加元素 arr.push(10);
    删除元素 arr.splice(0,1); //从0开始删除1个元素

  13. 字符串 var str = new String(s); 或者var str = s;
    可以通过length获取长度

    str.trim() //删除前后两端的空格

  14. 自定义对象
    var person{name:"张三";age:23;eat:function(){alert("干饭");}
    }person.name;
    person.eat;
    

BOM对象

Browser Obiect Model\

弹窗:

var flag = confirm("是否删除?");
if(flag){alert("删除成功!");
}else{;
}

定时器:

setTimeout(function(){alert("等待3s")}, 3000);//等待3s后弹一次
setInterval(function(){alert("等待3s")}, 3000);//间隔3s循环弹出

location.herf

<script>document.write("三秒后跳转到首页...");setTimeout(function(){location.href = "https://www.baidu.com";}, 3000)
</script>

DOM

Document Object Model
对HTML文档进行操作

对象获取

document.getElementById;
document.getElementsByName;
document.getElementsByClassName;
document.getElementsByTagName;

.src=“” 替换路径或者网址
.style 设置CSS样式
.innerHTML:设置元素内容

可以通过 https://www.w3school.com.cn/ 查看

事件监听

方式一:通过html标签绑定

<input type="button" onclick='on()'>function on(){alert("我被点了");
}

方式二:通过DOM元素属性绑定

<input type="button" id="btn">document.getElementByld("btn").οnclick=function(){alert("我被点了");
}

表单验证

<script>document.getElementById("register").onsubmit = function(){var username = document.getElementById("user").value;var passward = document.getElementById("pwd").value;if(username.length > 6){alert(username.length)alert("登陆成功!");return true;}else{alert("请重新输入!");return false;}}
</script>

HTTP

状态码:
https://cloud.tencent.com/developer/chapter/13553

HTTP请求数据格式

HTTP响应数据格式

Tomcat

tomcat是一个web服务器,支持Servlet/JSP等JavaEE规范。也可以称为servlet容器或者web容器。

将文件夹删除即可卸载软件。ctrl+C关闭tomcat。

使用:将java项目或前端项目放到tomcat/webapps文件夹下即可,为了提高复制速度,也可以打包成war文件直接复制过去(会自动解压缩),其他人即可通过浏览器访问。

端口号 :默认8080,在conf/server.xml中修改

Maven Web项目

项目结构

IDEA自动创建

Servlet

java提供的动态web开发技术,是一个java接口

  1. 创建web项目,导入Servlet坐标
  <dependencies><dependency><groupId>javax.servlet</groupId><artifactId>servlet-api</artifactId><version>2.5</version><scope>provided</scope></dependency></dependencies>
  1. 实现Servlet接口,重写所有方法,并在servlet中输出一句话,并在类上使用@WebServlet注解,配置访问路径
@WebServlet("/demo")
public calss ServletDemo implements Servlet{@Overridepublic coid service(){}
}
  1. 启动tomcat,在浏览器中输入URL访问Servlet。

常见错误

  • java: 错误: 不支持发行版本 6:解决Error java 错误 不支持发行版本

  • Cannot resolve symbol 'WebServlet: Idea报错Cannot resolve symbol ‘HttpServlet’

Servlet会被Tomcat创建

Servlet生命周期

以后经常使用HttpServlet(封装好的类),重写doGet和doPost方法即可。

request

package demo1;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.BufferedReader;
import java.io.IOException;
import java.util.Map;
import java.util.Set;@WebServlet("/demo")
public class ServletDemo1 extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {/*请求行*///获取请求方式String method = req.getMethod();System.out.println(method);//获取虚拟目录String contextPath = req.getContextPath();System.out.println(contextPath);//获取URL(统一资源定位符)StringBuffer url = req.getRequestURL();System.out.println(url.toString());//获取URI(统一资源标识符)String uri = req.getRequestURI();System.out.println(uri);//获取请求参数String queryString = req.getQueryString();System.out.println(queryString);//--------------------------------------------/*请求头*/String agent = req.getHeader("user-agent");System.out.println(agent);//获取输入参数的键值对Map<String, String[]> map = req.getParameterMap();Set<String> keySet=map.keySet();for (String key:keySet) {System.out.print(key + ":");String[] values = map.get(key);for(String value:values){System.out.print(value+" ");}System.out.println();}//获取对应的参数值String[] username = req.getParameterValues("username");for(String name:username){System.out.println(name);}}@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//获取字节输入流BufferedReader br = req.getReader();//读取数据String line = br.readLine();System.out.println(line);this.doGet(req,resp);}
}
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<!--将表单提交到/tomcat_demo_war/demo路径,Servlet会获取参数-->
<form action="/tomcat_demo_war/demo" method="get"><label><input type="text" name="username"></label><label><input type="password" name="password"></label><input type="submit">
</form>
</body>
</html>

解决中文乱码问题

//POST方式
req.setCharacterEncoding("UTF-8");
//GET方式
username = new String(username.getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8);

URL编码与解码

//编码
String encode = URLEncoder.encoder(str, "utf-8");
//解码
String decode = URLDecoder.decoder(encoder, "ISO-8859-1");
//字符转换为字节
byte[] bytes = getBytes("ISO-8859-1");
//将字节转换为字符串
new String(bytes, "utf-8");

请求转发(服务器内部共享资源,分工合作),不用加虚拟目录

request.getRequestDispatcher("/path").forward(request, response);

response

重定向:自动跳转到其他资源

response中文乱码

resp.setContentType("text/html;charset=utf-8");//获取输出流
PrintWriter writer = resp.getWriter();
writer.write("aaa");

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

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

相关文章

MYSQL存储

注意&#xff1a; 1.如果没有指定的SESSION/GLOBAL&#xff0c;默认是SESSION&#xff0c;会话变量。 2.mysql服务重新启动之后&#xff0c;所设置的全局参数会失效&#xff0c;要想不失效&#xff0c;可以在/etc/my.cnf中配置。 变量 用户定义变量是用户根据需要自己定义变量…

Redis队列stream,Redis多线程详解

Redis 目前最新版本为 Redis-6.2.6 &#xff0c;会以 CentOS7 下 Redis-6.2.4 版本进行讲解。 下载地址&#xff1a; https://redis.io/download 安装运行 Redis 很简单&#xff0c;在 Linux 下执行上面的 4 条命令即可 &#xff0c;同时前面的 课程已经有完整的视…

《尚品甄选》:后台系统——权限管理之分类和品牌管理,使用EasyExcel导入导出数据(debug一遍)

文章目录 一、分类管理1.1 表结构介绍1.2 分类列表查询 二、EasyExcel使用2.1 EasyExcel简介2.2 导出功能2.3 导入功能 三、品牌管理3.1 表结构介绍3.2 列表查询3.3 添加品牌3.4 修改品牌3.5 删除品牌 一、分类管理 分类管理就是对商品的分类数据进行维护。 1.1 表结构介绍 分…

缺省参数的声明和定义

首先&#xff0c;函数缺省参数不能同时出现在声明和定义中&#xff0c;如出现则报错&#xff1a; 声明和定义中同时出现缺省参数 ctrlb&#xff0c;编译报错&#xff0c;提示 “test"&#xff1a;重定义默认参数&#xff1a;参数1 编译报错 当函数的声明和定义中都出现…

第10关:基数排序

任务要求参考答案问答98 任务描述相关知识 基数排序算法编程要求测试说明 任务描述 本关任务&#xff1a;实现基数排序算法&#xff0c;并将乱序数列变成升序。 相关知识 为了完成本关任务&#xff0c;你需要掌握&#xff1a;1.基数排序算法。 基数排序算法 基数排序是按…

Node.js下载安装教程

一、下载安装包 1、百度网盘自提链接&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1Bbw895MtUgjlfZylPHCCxw 提取码&#xff1a;x89v 2、进入官网下载 https://nodejs.org/zh-cn/download/ 选择对应版本&#xff0c;我这里选的windows64位版本 二、安装程序 1、…

使用shell快速查看电脑曾经连接过的WiFi密码

此方法只能查看以前连接过的wifi名称和对应的密码 查看连接过的WiFi名称netsh wlan show profiles查看具体的WiFi名称netsh wlan show profile name"你的wifi名称" keyclear

vivado综合分析与收敛技巧1

使用细化视图对 RTL 进行最优化 完成任意实现步骤后使用 report_timing 、 report_timing_summary 或 report_design_analysis 分析时序结果时&#xff0c; 您必须审查关键路径结构 &#xff0c; 了解是否可通过修改 RTL 、使用综合属性或者使用其他综合选项来更有效地将…

LeetCode.24两两交换链表中的节点

LeetCode.24两两交换链表中的节点 1.问题描述2.解题思路3.代码 1.问题描述 给你一个链表&#xff0c;两两交换其中相邻的节点&#xff0c;并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题&#xff08;即&#xff0c;只能进行节点交换&#xff09;。 示…

雷达公式实现(matlab)

雷达公式实现 代码来源&#xff1a;《雷达系统分析与设计(MATLAB版)(第三版)》 function [snr] radar_eq(pt,freq,g,sigma,b,nf,loss,range) % This program implements Eq.(1.63) %% Inputs:% pt——峰值功率&#xff0c;W% freq——雷达中心频率&#xff0c;Hz% g——天线…

IntelliJ IDEA 中有什么让你相见恨晚的技巧

一、条件断点 循环中经常用到这个技巧&#xff0c;比如&#xff1a;遍历1个大List的过程中&#xff0c;想让断点停在某个特定值。 参考上图&#xff0c;在断点的位置&#xff0c;右击断点旁边的小红点&#xff0c;会出来一个界面&#xff0c;在Condition这里填入断点条件即可&…

AI旅游:旅游行业的人工智能成熟艺术适应从实践到表现报告

今天分享的是AI系列深度研究报告&#xff1a;《AI旅游&#xff1a;旅游行业的人工智能成熟艺术适应从实践到表现报告》。 &#xff08;报告出品方&#xff1a;accenture&#xff09; 报告共计&#xff1a;25页 旅行还没有充分利用AI所能做的一 而旅游业比两年前强多了。公司…

如何通过Portal实现消息集成

在数字化时代浪潮下&#xff0c;信息的流通与交互已变得至关重要&#xff0c;不论是在企业内部日常协作&#xff0c;还是与外部客户的紧密沟通&#xff0c;信息的快速、准确、实时传递都成为了确保业务顺畅进行的关键因素、决策精准的核心要素。 为了满足这种日益增长的需求&a…

flask web开发学习之初识flask(一)

一、概念 flask是一个使用python编写的轻量级web框架&#xff0c;作者为Armin Ronacher&#xff08;中文名&#xff1a;阿尔敏罗纳彻&#xff09;&#xff0c;它广泛被应用于web开发和API。flask提供了简洁而灵活地方式来构建web应用&#xff0c;它不会强加太多约束&#xff0…

PyCharm简介与安装

pyCharm的作用 PyCharm是一种Python的集成开发环境&#xff0c;带有一整套可以帮助用户在使用Python语言开发时提高效率的工具 pyCharm的集成 pyCharm的分类 PyCharm的下载 网址&#xff1a;https://www.jetbrains.com/pycharm/download/#sectionwindows PyCharm的安装

第五届全国高校计算机能力挑战赛-程序设计挑战赛(C语言模拟题)

1、已有定义“int a[10]{1,2},i0;”&#xff0c;下面语句中与“ a[i]a[i1],i;”等价的是()。 A. a[i]a[i1]; B. a[i]a[i]; C. a[i]a[i1]; D. i,a[i-1]a[i]; 2、两次运行下面的程序&#xff0c;如果从键盘上分别输入6和4&#xff0c;则输出结果是(&#xff09;。 A. 7和5 …

3D打印报价系统

一款3d打印报价系统不仅可以展示三维模型&#xff0c;还能自动计算模型的相关信息&#xff0c;如面积、体积和尺寸信息。 用户上传三维模型后&#xff0c;系统会自动为其生成一个报价页面。在这个页面上&#xff0c;用户可以看到他们模型的所有相关信息&#xff0c;包括面积、体…

常用的系统播放器——MediaPlayer生命周期

常用的系统播放器——MediaPlayer 状态图以及生命周期 Idle状态、End状态、Error状态 MediaPlayer创建实例或者调用reset&#xff08;&#xff09;后就处于Idle状态&#xff0c;即就绪。 任意时刻调用release&#xff08;&#xff09;就会进入End 当运行过程中出错&#xf…

鼎捷副总裁谢丽霞:从四大趋势来看,数智时代企业如何加速研发创新

目录 导读 01 研发创新 势不可挡 ① 从逆向设计走向正向设计 ② 从专业协助走向全面协同 ③ 从单点场景走向业务闭环 ④ 从知识管理走向知识工程 02 鼎捷雅典娜 数智驱动企业新未来 03 鼎捷PLM 赋能企业研发创新 导读 研发&#xff0c;企业长青的必备源动能。如何在…

孩子写作业用的护眼灯哪种好?适合考研的护眼台灯推荐

随着现在小孩子的近视率越来越高&#xff0c;全国中小学生近视比率占大多数&#xff0c;许多家长也开始为孩子的健康成长而担忧&#xff0c;这时很多家长就会选择护眼台灯来为孩子保驾护航。但面对市面上五花八门的台灯品牌&#xff0c;各式各样的台灯许多家长却乱了阵脚&#…