web服务器-tomcat-servlet-request-response-Filter-http-BeanUtils笔记

web服务器-tomcat-servlet-request-response-Filter-http-BeanUtils

内容基本是黑马视频笔记,偶尔会加些个人补充,仅作为复习巩固用途。如有错误,请指出,谢谢。

web服务器软件

* 服务器:安装了服务器软件的计算机
* 服务器软件:接收用户的请求,处理请求,做出响应
* web服务器软件:接收用户的请求,处理请求,做出响应。
	* 在web服务器软件中,可以部署web项目,让用户通过浏览器来访问这些项目

* 常见的java相关的web服务器软件:
	* webLogic:oracle公司,大型的JavaEE服务器,支持所有的JavaEE规范,收费的。
	* webSphere:IBM公司,大型的JavaEE服务器,支持所有的JavaEE规范,收费的。
	* JBOSS:JBOSS公司的,大型的JavaEE服务器,支持所有的JavaEE规范,收费的。
	* Tomcat:Apache基金组织,中小型的JavaEE服务器,仅仅支持少量的JavaEE规范servlet/jsp。开源的,免费的。

* JavaEE:Java语言在企业级开发中使用的技术规范的总和,一共规定了13项大的规范

Tomcat:web服务器软件

1. 下载:http://tomcat.apache.org/
2. 安装:解压压缩包即可。
	* 注意:安装目录建议不要有中文和空格
3. 卸载:删除目录就行了
4. 启动:
	* bin/startup.bat ,双击运行该文件即可
	* 访问:浏览器输入:http://localhost:8080 回车访问自己
					  http://别人的ip:8080 访问别人
	
	* 可能遇到的问题:
		1. 黑窗口一闪而过:
			* 原因: 没有正确配置JAVA_HOME环境变量
			* 解决方案:正确配置JAVA_HOME环境变量

		2. 启动报错:
			1. 暴力:找到占用的端口号,并且找到对应的进程,杀死该进程
				* netstat -ano
			2. 温柔:修改自身的端口号
				* conf/server.xml
				* <Connector port="8888" protocol="HTTP/1.1"
	               connectionTimeout="20000"
	               redirectPort="8445" />
				* 一般会将tomcat的默认端口号修改为80。80端口号是http协议的默认端口号。
					* 好处:在访问时,就不用输入端口号
5. 关闭:
	1. 正常关闭:
		* bin/shutdown.bat
		* ctrl+c
	2. 强制关闭:
		* 点击启动窗口的×
6. 配置:
	* 部署项目的方式:
		1. 直接将项目放到webapps目录下即可。
			* /hello:项目的访问路径-->虚拟目录
			* 简化部署:将项目打成一个war包,再将war包放置到webapps目录下。
				* war包会自动解压缩

		2. 配置conf/server.xml文件
			在<Host>标签体中配置
			<Context docBase="D:\hello" path="/hehe" />
			* docBase:项目存放的路径
			* path:虚拟目录

		3. 在conf\Catalina\localhost创建任意名称的xml文件。在文件中编写
			<Context docBase="D:\hello" />
			* 虚拟目录:xml文件的名称
	
	* 静态项目和动态项目:
		* 目录结构
			* java动态项目的目录结构:
				-- 项目的根目录
					-- WEB-INF目录:
						-- web.xml:web项目的核心配置文件
						-- classes目录:放置字节码文件的目录,编译后的文件基本放在这,包括一些连接池等配置文件
						-- lib目录:放置依赖的jar包

	* 将Tomcat集成到IDEA中,并且创建JavaEE的项目,部署项目。

Servlet: server applet

* 概念:运行在服务器端的小程序
	* Servlet就是一个接口,定义了Java类被浏览器访问到(tomcat识别)的规则。
	* 将来我们自定义一个类,实现Servlet接口,复写方法。

* 快速入门:
	1. 创建JavaEE项目
	2. 定义一个类,实现Servlet接口
		* public class ServletDemo1 implements Servlet
	3. 实现接口中的抽象方法
	4. 配置Servlet,可以采用xml或注解,注解方便,xml清晰。
		 在web.xml中配置:
	    <!--配置Servlet 
	    url-pattern与servlet-class对应起来	-->
	    <servlet>
	        <servlet-name>demo1</servlet-name>
	        <servlet-class>cn.itcast.web.servlet.ServletDemo1</servlet-class> // 全限定类名
	    </servlet>
	
	    <servlet-mapping>
	        <servlet-name>demo1</servlet-name>
	        <url-pattern>/demo1</url-pattern> // 路径
	    </servlet-mapping>

Servlet执行原理

	1. 当服务器接受到客户端浏览器的请求后,会解析请求URL路径,获取访问的Servlet的资源路径
	2. 查找web.xml文件,是否有对应的<url-pattern>标签体内容。
	3. 如果有,则在找到对应的<servlet-class>全类名
	4. tomcat会将字节码文件加载进内存,并且创建其对象。这属于延迟创建,需要时才创建
	5. 调用其方法

* Servlet中的生命周期方法:
	1. 被创建:执行init方法,只执行一次
		* Servlet什么时候被创建?
			* 默认情况下,第一次被访问时,Servlet被创建
			* 可以配置执行Servlet的创建时机。
				* 在<servlet>标签下配置
					1. 第一次被访问时,创建
                		* <load-on-startup>的值为负数
		            2. 在服务器启动时,创建
		                * <load-on-startup>的值为0或正整数


		* Servlet的init方法,只执行一次,说明一个Servlet在内存中只存在一个对象,Servlet是单例的
			* 多个用户同时访问时,可能存在线程安全问题。
			* 解决:尽量不要在Servlet中定义成员变量。即使定义了成员变量,也不要对修改值

	2. 提供服务:执行service方法,执行多次。理解:分发方法,反射执行。
		* 每次访问Servlet时,Service方法都会被调用一次。
	3. 被销毁:执行destroy方法,只执行一次
		* Servlet被销毁时执行。服务器关闭时,Servlet被销毁
		* 只有服务器正常关闭时,才会执行destroy方法。
		* destroy方法在Servlet被销毁之前执行,一般用于释放资源
		
* Servlet3.0:
	* 好处:
		* 支持注解配置。可以不需要web.xml了。

	* 步骤:
		1. 创建JavaEE项目,选择Servlet的版本3.0以上,可以不创建web.xml
		2. 定义一个类,实现Servlet接口
		3. 复写方法
		4. 在类上使用@WebServlet注解,进行配置,此注解在类上,运行期
			@WebServlet("资源路径")  // 资源路径称为servlet路径,
			//	一个Servlet可以定义多个访问路径
			//	路径定义规则:
				1. /xxx:路径匹配
				2. /xxx/xxx:多层路径,目录结构
				3. *.do:扩展名匹配
			
			@Target({ElementType.TYPE})
			@Retention(RetentionPolicy.RUNTIME)
			@Documented
			public @interface WebServlet {
			    String name() default "";	//相当于<Servlet-name>
			
			    String[] value() default {};	//代表urlPatterns()属性配置
			
			    String[] urlPatterns() default {};	//相当于<url-pattern>
			
			    int loadOnStartup() default -1;	//相当于<load-on-startup>
			
			    WebInitParam[] initParams() default {};
			
			    boolean asyncSupported() default false;
			
			    String smallIcon() default "";
			
			    String largeIcon() default "";
			
			    String description() default "";
			
			    String displayName() default "";
			}

Servlet的体系结构

				Servlet -- 接口
					|
				GenericServlet -- 抽象类
					|
				HttpServlet  -- 抽象类

补充:
Interface Servlet:		javax.servlet

Abstract Class GenericServlet
		extend class:
			Object 
		All Implemented Interfaces: 
			Serializable, Servlet, ServletConfig 

Abstract  Class HttpServlet
		extend class:
			GenericServlet
		All Implemented Interfaces: 
			Serializable, Servlet, ServletConfig 

* GenericServlet:将Servlet接口中其他的方法做了默认空实现,只将service()方法作为抽象
	* 将来定义Servlet类时,可以继承GenericServlet,实现service()方法即可

* HttpServlet:对http协议的一种封装,简化操作
	1. 定义类继承HttpServlet
	2. 复写doGet/doPost方法
继承GenericServlet或HttpServlet看你需要实现什么样的方法

Request对象

1. request对象和response对象的原理
	1. request和response对象是由服务器创建的。我们来使用它们
	2. request对象是来获取请求消息,response对象是来设置响应消息

2. request对象继承体系结构:	
			ServletRequest		--	接口
				|	继承
			HttpServletRequest	-- 接口
				|	实现
			org.apache.catalina.connector.RequestFacade 类(tomcat)
补充:
		Interface ServletRequest:		javax.servlet
				All Known Subinterfaces: 
					HttpServletRequest 
	
		Interface HttpServletRequest:		javax.servlet.http
				All Superinterfaces: 
					ServletRequest 

3. request功能:
	1. 获取请求消息数据
		1. 获取请求行数据
			* GET /day14/demo1?name=zhangsan HTTP/1.1
			* 方法:
				1. 获取请求方式 :GET
					* String getMethod()  
				2. (*)获取虚拟目录:/day14
					* String getContextPath()
				3. 获取Servlet路径: /demo1
					* String getServletPath()
				4. 获取get方式请求参数:name=zhangsan
					* String getQueryString()
				5. (*)获取请求URI:/day14/demo1
					* String getRequestURI():		/day14/demo1
					* StringBuffer getRequestURL()  :http://localhost/day14/demo1

					* URL:统一资源定位符 : http://localhost/day14/demo1	中华人民共和国
					* URI:统一资源标识符 : /day14/demo1					共和国
				
				6. 获取协议及版本:HTTP/1.1
					* String getProtocol()

				7. 获取客户机的IP地址:
					* String getRemoteAddr()

Request获取请求参数通用方式:不论get还是post请求方式都可以使用下列方法来获取请求参数

1. String getParameter(String name):根据参数名称获取参数值    username=zs&password=123
2. String[] getParameterValues(String name):根据参数名称获取参数值的数组  hobby=xx&hobby=game
3. Enumeration<String> getParameterNames():获取所有请求的参数名称
4. Map<String,String[]> getParameterMap():获取所有参数的map集合
			
		获取请求体数据:
			* 请求体:只有POST请求方式,才有请求体,在请求体中封装了POST请求的请求参数

注意:以后会频繁碰到类似中文乱码问题,需要再次总结。

get方式:tomcat 8 已经将get方式乱码问题解决了
post方式:会乱码
	* 解决:在获取参数前,设置request的编码request.setCharacterEncoding("utf-8");

Request请求转发:一种在服务器内部的资源跳转方式

1. 步骤:
	1. 通过request对象获取请求转发器对象:RequestDispatcher getRequestDispatcher(String path)
	2. 使用RequestDispatcher对象来进行转发:forward(ServletRequest request, ServletResponse response) 
2. 特点:
	1. 浏览器地址栏路径不发生变化
	2. 只能转发到当前服务器内部资源中。
	3. 转发是一次请求

Request域以及ServletContext域

* 域对象:一个有作用范围的对象,可以在范围内共享数据
1、 request域:代表一次请求的范围,一般用于请求转发的多个资源中共享数据
* 方法:
	1. void setAttribute(String name,Object obj):存储数据
	2. Object getAttitude(String name):通过键获取值
	3. void removeAttribute(String name):通过键移除键值对
2、ServletContext域:代表整个web应用,可以和程序的容器(服务器)来通信
	1、获取ServletContext域:
			1. 通过request对象获取
				request.getServletContext();
			2. 通过HttpServlet获取
				this.getServletContext();
	2. 功能:
			1. 获取MIME类型:
				* MIME类型:在互联网通信过程中定义的一种文件数据类型
					* 格式: 大类型/小类型   text/html		image/jpeg
				* 获取:String getMimeType(String file)  
			2. 域对象:共享数据
				1. setAttribute(String name,Object value)
				2. getAttribute(String name)
				3. removeAttribute(String name)

				* ServletContext对象范围:所有用户所有请求的数据
			3. 获取文件的真实(服务器)路径
				1. 方法:String getRealPath(String path)  

注意
ServletContext域

1、若想在response中返回指定类型数据,需要先获取MIME类型,然后设置返回体
2、共享服务器数据
3、获取服务器下文件的路径

**Request域:**携带一次请求的信息,更加灵活

Response对象

* 功能:设置响应消息
	1. 设置响应行
		1. 格式:HTTP/1.1 200 ok
		2. 设置状态码:setStatus(int sc) 
	2. 设置响应头:setHeader(String name, String value) 
	3. 设置响应体:
		* 使用步骤:
			1. 获取输出流
				* 字符输出流:PrintWriter getWriter()
				* 字节输出流:ServletOutputStream getOutputStream()
			2. 使用输出流,将数据输出到客户端浏览器

Response完成重定向

* 重定向:资源跳转的方式
* 代码实现:
	//1. 设置状态码为302
    response.setStatus(302);
    //2.设置响应头location
    response.setHeader("location", url);

    //简单的重定向方法
    response.sendRedirect(url);

forward 和 redirect 区别:
重定向的特点:redirect

1. 地址栏发生变化
2. 重定向可以访问其他站点(服务器)的资源
3. 重定向是两次请求。不能使用request对象来共享数据

转发的特点:forward

1. 转发地址栏路径不变
2. 转发只能访问当前服务器下的资源
3. 转发是一次请求,可以使用request对象来共享数据

注意路径写法

1. 路径分类
1. 相对路径:通过相对路径不可以确定唯一资源
	* 如:./index.html
	* 不以/开头,以.开头路径

	* 规则:找到当前资源和目标资源之间的相对位置关系
		* ./:当前目录
		* ../:后退一级目录
2. 绝对路径:通过绝对路径可以确定唯一资源
	*/开头的路径,这一点很重要

	* 规则:判断定义的路径是给谁用的?判断请求将来从哪儿发出
		* 给客户端浏览器使用:需要加虚拟目录(项目的访问路径)
			* 建议虚拟目录动态获取:request.getContextPath()
			* <a> , <form> 重定向...
		* 给服务器使用:不需要加虚拟目录
			* 转发路径

Response完成服务器输出字符数据到浏览器

//简单的形式,设置编码,是在获取流之前设置
			response.setContentType("text/html;charset=utf-8");
* 步骤:
	1. 获取字符输出流
	2. 输出数据
* 注意:
	* 乱码问题:
		1. PrintWriter pw = response.getWriter();中文操作系统获取的流的默认编码是ISO-8859-1
		2. 设置该流的默认编码
		3. 告诉浏览器响应体使用的编码

Response完成服务器输出字节数据到浏览器,适合无需考虑字符编码的情况,例如图片

* 步骤:
	1. 获取字节输出流
	2. 输出数据

Filter:过滤器

1. 概念:
	web中的过滤器:当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能。
	* 过滤器的作用:
		* 一般用于完成通用的操作。如:登录验证、统一编码处理、敏感字符过滤...

2. 快速入门:
	1. 步骤:
		1. 定义一个类,实现接口Filter
		2. 复写方法
		3. 配置拦截路径
			1. web.xml
			2. 注解
	2. 代码:
@WebFilter("/*")//访问所有资源之前,都会执行该过滤器
public class FilterDemo1 implements Filter {
	// 初始化加载一些配置信息
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
    
    }
    // 真正过滤逻辑
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("filterDemo1被执行了....");
        //放行
        filterChain.doFilter(servletRequest,servletResponse);
    }
	// 过滤完释放某些资源
    @Override
    public void destroy() {

    }
}
3. 过滤器细节:
	1. web.xml配置	
		<filter>
	        <filter-name>demo1</filter-name>
	        <filter-class>全限定类名</filter-class>
	    </filter>
	    <filter-mapping>
	        <filter-name>demo1</filter-name>
			<!-- 拦截路径 -->
	        <url-pattern>/*</url-pattern> // 路径
	    </filter-mapping>
	2. 过滤器执行流程
		1. 执行过滤器
		2. 执行放行后的资源
		3. 回来执行过滤器放行代码下边的代码
	3. 过滤器生命周期方法
		1. init:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次。用于加载资源
		2. doFilter:每一次请求被拦截资源时,会执行。执行多次
		3. destroy:在服务器关闭后,Filter对象被销毁。如果服务器是正常关闭,则会执行destroy方法。只执行一次。用于释放资源
	4. 过滤器配置详解
		* 拦截路径配置:
			1. 具体资源路径: /index.jsp   只有访问index.jsp资源时,过滤器才会被执行
			2. 拦截目录: /user/*	访问/user下的所有资源时,过滤器都会被执行
			3. 后缀名拦截: *.jsp		访问所有后缀名为jsp资源时,过滤器都会被执行
			4. 拦截所有资源:/*		访问所有资源时,过滤器都会被执行
		* 拦截方式配置:资源被访问的方式
			* 注解配置:
				* 设置dispatcherTypes属性
					1. REQUEST:默认值。浏览器直接请求资源
					2. FORWARD:转发访问资源
					3. INCLUDE:包含访问资源
					4. ERROR:错误跳转资源
					5. ASYNC:异步访问资源
			* web.xml配置
				* 设置<dispatcher></dispatcher>标签即可
			
	5. 过滤器链(配置多个过滤器)
		* 执行顺序:如果有两个过滤器:过滤器1和过滤器2
			1. 过滤器1
			2. 过滤器2
			3. 资源执行
			4. 过滤器2
			5. 过滤器1 

		* 过滤器先后顺序问题:
			1. 注解配置:按照类名的字符串比较规则比较,值小的先执行
				* 如: AFilter 和 BFilter,AFilter就先执行了。
			2. web.xml配置: <filter-mapping>谁定义在上边,谁先执行

增强对象的功能:后续需要详细补充

* 设计模式:一些通用的解决固定问题的方式
1. 装饰模式
2. 代理模式
	* 概念:
		1. 真实对象:被代理的对象
		2. 代理对象:
		3. 代理模式:代理对象代理真实对象,达到增强真实对象功能的目的
 	* 实现方式:
	 	1. 静态代理:有一个类文件描述代理模式
	 	2. 动态代理:在内存中形成代理类
			* 实现步骤:
				1. 代理对象和真实对象实现相同的接口
				2. 代理对象 = Proxy.newProxyInstance();
				3. 使用代理对象调用方法。
				4. 增强方法

			* 增强方式:
				1. 增强参数列表
				2. 增强返回值类型
				3. 增强方法体执行逻辑	

Listener:监听器,不太熟悉

* 概念:web的三大组件之一。
	* 事件监听机制
		* 事件	:一件事情
		* 事件源 :事件发生的地方
		* 监听器 :一个对象
		* 注册监听:将事件、事件源、监听器绑定在一起。 当事件源上发生某个事件后,执行监听器代码


* ServletContextListener:监听ServletContext对象的创建和销毁
	* 方法:
		* void contextDestroyed(ServletContextEvent sce) :ServletContext对象被销毁之前会调用该方法
		* void contextInitialized(ServletContextEvent sce) :ServletContext对象创建后会调用该方法
	* 步骤:
		1. 定义一个类,实现ServletContextListener接口
		2. 复写方法
		3. 配置
			1. web.xml
					<listener>
 					 <listener-class>监听类的全限定类名</listener-class>
					</listener>

					* 指定初始化参数<context-param>
			2. 注解:
				* @WebListener

HTTP:

* 概念:Hyper Text Transfer Protocol 超文本传输协议
	* 传输协议:定义了,客户端和服务器端通信时,发送数据的格式
	* 特点:
		1. 基于TCP/IP的高级协议
		2. 默认端口号:80
		3. 基于请求/响应模型的:一次请求对应一次响应
		4. 无状态的:每次请求之间相互独立,不能交互数据

	* 历史版本:
		* 1.0:每一次请求响应都会建立新的连接
		* 1.1:复用连接

HTTP消息数据格式

* 数据格式:
	1. 请求行
	2. 请求头
	3. 请求空行
	4. 请求体
请求消息:客户端发送给服务器端的数据
1 请求行
	请求方式 请求url 请求协议/版本
	GET /login.html	HTTP/1.1
	* 请求方式:
		* HTTP协议有7中请求方式,常用的有2种
			* GET:
				1. 请求参数在请求行中,在url后。
				2. 请求的url长度有限制的
				3. 不太安全
			* POST:
				1. 请求参数在请求体中
				2. 请求的url长度没有限制的
				3. 相对安全

2. 请求头:客户端浏览器告诉服务器一些信息
	请求头名称: 请求头值
	* 常见的请求头:
		1. User-Agent:浏览器告诉服务器,我访问你使用的浏览器版本信息
			* 可以在服务器端获取该头的信息,解决浏览器的兼容性问题

		2. Referer:http://localhost/login.html
			* 告诉服务器,我(当前请求)从哪里来?
				* 作用:
					1. 防盗链:
					2. 统计工作:
3. 请求空行
	空行,就是用于分割POST请求的请求头,和请求体的。
4. 请求体(正文):
	* 封装POST请求消息的请求参数的
		* 字符串格式:
			POST /login.html	HTTP/1.1
			Host: localhost
			User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0
			Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
			Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
			Accept-Encoding: gzip, deflate
			Referer: http://localhost/login.html
			Connection: keep-alive
			Upgrade-Insecure-Requests: 1
			
			username=zhangsan	
响应消息:服务器端发送给客户端的数据
1. 响应行
	1. 组成:协议/版本 响应状态码 状态码描述
	2. 响应状态码:服务器告诉客户端浏览器本次请求和响应的一个状态。
		1. 状态码都是3位数字 
		2. 分类:
			1. 1xx:服务器就收客户端消息,但没有接受完成,等待一段时间后,发送1xx多状态码
			2. 2xx:成功。代表:200
			3. 3xx:重定向。代表:302(重定向),304(访问缓存)
			4. 4xx:客户端错误。
				* 代表:
					* 404(请求路径没有对应的资源) 
					* 405:请求方式没有对应的doXxx方法
			5. 5xx:服务器端错误。代表:500(服务器内部出现异常)
				
2. 响应头:
	1. 格式:头名称: 值
	2. 常见的响应头:
		1. Content-Type:服务器告诉客户端本次响应体数据格式以及编码格式
		2. Content-disposition:服务器告诉客户端以什么格式打开响应体数据
			* 值:
				* in-line:默认值,在当前页面内打开
				* attachment;filename=xxx:以附件形式打开响应体。文件下载
3. 响应空行
4. 响应体:传输的数据

BeanUtils工具类,简化数据封装,后面spring提供封装

* 用于封装JavaBean的
1. JavaBean:标准的Java类
	1. 要求:
		1. 类必须被public修饰
		2. 必须提供空参的构造器
		3. 成员变量必须使用private修饰
		4. 提供公共setter和getter方法
	2. 功能:封装数据

2. 概念:
	成员变量:
	属性:setter和getter方法截取后的产物
		例如:getUsername() --> Username--> username

3. 方法:
	1. setProperty()
	2. getProperty()
	3. populate(Object obj , Map map):将map集合的键值对信息,封装到对应的JavaBean对象中

IDEA与tomcat的相关配置,这里后续可能详细补充或者加入其它博客链接

1. IDEA会为每一个tomcat部署的项目单独建立一份配置文件
	* 查看控制台的log:Using CATALINA_BASE

2. 工作空间项目    和     tomcat部署的web项目
	* tomcat真正访问的是“tomcat部署的web项目”,"tomcat部署的web项目"对应着"工作空间项目" 的web目录下的所有资源
	* WEB-INF目录下的资源不能被浏览器直接访问。
3. 断点调试
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值