java–JSP

本文介绍了JSP的基本概念,包括JSP元素、输出、注释、方法及指令等内容,并详细讲解了page指令的各种属性,还涉及了JSP标签、内置对象及其配置。

======================================================
注:本文源代码点此下载
======================================================

jsp看起来像html,其中html代码叫做模板数据,java scriptlet代码叫做jsp元素。

 

jsp是一种servlet,但与httpservlet的工作方式又不太一样。第一次访问jsp时,tomcat会先将jsp转为标准的java代码,然后将java代码编译为class文件,最后运行class,以后访问时,jsp不该动的情况下,会一直调用这个class。

 

看看转化过的jsp java类文件源码,可以发现,jsp和servlet基本没啥区别。

 

 

jsp标签

jsp脚本必须使用 括起来,语句必须遵循java语法。

 

jsp输出

在servlet中,输出语句是 out.println(),这里jsp中的等效语法是。

数字的乘阶是:

 

jsp注释

在jsp元素中,可以使用java的标准注释,也可以使用注释标

 

jsp方法

所有标签都会被原封不动的翻译为servlet中doget这样的方法中,在方法中是无法定义方法的。

而标签,可以方便的定义自己的方法,它会被翻译在默认方法外。

数字

 

jsp指令

jsp指令用来声明jsp页面的一些属性等,例如编码方式,文档类型。。。格式

 

    page指令

用来声明jsp页面的属性。

 

page指令的常见属性( jsp 2.1规范)

属 性 名 称

取 值 范 围

描        述

language

java

指明解释该jsp文件时采用的语言。一般为java,默认为java。

extends

任何类的全名

指明编译该jsp文件时继承哪个类。jsp为servlet,因此当指明继承普通类时需要实现servlet的init、destroy等方法。

import

任何包名,类名

引入包或类。与java中的import作用相同。一个import语句也可以引入多个类:

jsp中,以下四个包里的类可以直接使用:

java.lang.*;javax.servlet.*;javax.servlet.jsp.*;javax.servlet.http.*

session

true , false

指明该jsp是否内置session对象。默认为true,存储session对象

autoflush

true , false

是否运行缓存,默认为true,使用out.println()输出字符串,并不是立刻到达客户端,暂时存在缓存里,等待程序执行完毕或者out.flus(),字符才发送到客户端。

buffer

none 或者

xx(数字)kb

当autoflush为true时,制定缓存大小。例如:

isthreadsafe

true , false

是否线程安全。默认为false,如果为ture,则运行多个线程同时运行该jsp程序,否则只一个线程运行,其它线程等待。

iserrorpage

true , false

指定本jsp是否为错误处理页面。默认为false,如果为true,内置了一个exception对象exception,可以直接使用

errorpage

某个jsp页面的

相对路径

指明一个错误显示页面。如果该jsp抛出了一个未被捕捉的异常,则转到指定的页面。指定的页面通常iserrorpage为true。

contenttype

有效地文档类型

客户端浏览器根据该属性判断文档类型。例如:

html : text/html

纯文本格式 : text/plain

jpg : image/jpeg

gif : image/gif

word : application/msword

info

任意字符串

指明jsp信息。该信息可以通过 servlet.getservletinfo()方法得到。

trimdirective

whitespaces

true , false

是否去掉指令前后的空白字符。默认为false。

输出xml时,尽量设置为true吧。

 

    include指令

包含页面。

这里的include是静态引入,也就是说,tomcat会把引入的jsp编译为一个class,最后运行的事整合后的servlet。

            被引入的文件必须遵循jsp语法。

            被引入的文件可以使用任意的扩展名,即使其扩展名是html,jsp引擎也会按照处理jsp页面的方式处理它里面的内容,为了见明知意,jsp规范建议使用.jspf(jsp fragments)作为静态引入文件的扩展名。

            由于使用include指令将会涉及到2个jsp页面,并会把2个jsp翻译成一个servlet,所以这2个jsp页面的指令不能冲突(除了pageencoding和导包除外)。

 

jsp标签

jsp actions,有人叫标签,有人叫动作,有人叫行为,都是一回事。jsp标签就是对常用的jsp功能的抽象的封装,优点就是代码少,方便维护,代码美观。jsp标签有内置的标准标签,也可以自定义标签。这里只说说默认的标签。

 

    标签

不同于,属于动态包含,也就是不编译为一个class,而是在运行时分别获取运行结果然后包含,等同于页面包含了html,这段html这样跳转过去 request.getrequestdispatcher(“url”).forward(request,response) 。

//flush指明,在插入其他资源的输出内容时,是否先将当前jsp页面的已输出的内容刷新到客户端。

这里是正文

 

    标签

        标签

页面跳转,等同于 request.getrequestdispatcher(“url”).forward(request,response) 。是转发时携带的地址栏参数。

注意的是,转发前不能向浏览器输出内容,否则抛出illegalstateexception

 

    标签

        标签

        标签

顾名思义,使用javabean。格式是这样的:

id就是javabean的变量名,class是完整类名,scope是作用域,有四个作用域:

page    该jsp内有效

request   当前request内有效

session  当前会话(用户)有效

application   web应用内有效

setproperty就是设置属性

  beanid就是以声明的bean的变量名,property为属性,value是值。

  这里,是把request提交内容填充至bean,前提是这个bean必须有对应的属性。

getproperty是获取属性值

这个就不解释了。

 

jsp九大隐藏对象

out                --javax.servlet.jsp.jspwriter

request          --javax.servlet.servletrequest

response        --javax.servlet.servletresponse

config           --javax.servlet.servletconfig

session          --javax.servlet.http.httpsession

application     --javax.servlet.servletcontext

page              --javax.servlet.jsp.httpjsppage  这个就等于 this

pagecontext   --javax.servlet.jsp.pagecontext  这个很重要,它代表了jsp的运行环境,可以获得这上面所有对象

exception       --java.lang.exception

 

jsp配置

simplejspservlet

/jsp/simple.jsp

simplejspservlet

/xxx/yyy.html


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> <display-name>AirlineBooking</display-name> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> <!-- 配置JSTL --> <jsp-config> <taglib> <taglib-uri>http://java.sun.com/jsp/jstl/core</taglib-uri> <taglib-location>/WEB-INF/lib/jstl-1.2.jar</taglib-location> </taglib> </jsp-config> <filter> <filter-name>AuthFilter</filter-name> <filter-class>com.airline.filter.AuthFilter</filter-class> </filter> <filter-mapping> <filter-name>AuthFilter</filter-name> <url-pattern>/booking/*</url-pattern> </filter-mapping> <filter-mapping> <filter-name>AuthFilter</filter-name> <url-pattern>/user/*</url-pattern> </filter-mapping> <!-- <!– 应用显示名称 –>--> <!-- <display-name>OnlineShop</display-name>--> <!-- <!– 欢迎文件列表 –>--> <!-- <welcome-file-list>--> <!-- <welcome-file>index.jsp</welcome-file>--> <!-- </welcome-file-list>--> <!-- <!– 会话超时配置(单位:分钟) –>--> <!-- <session-config>--> <!-- <session-timeout>30</session-timeout>--> <!-- </session-config>--> <!-- <!– Servlet 配置 –>--> <!-- <servlet>--> <!-- <servlet-name>LoginServlet</servlet-name>--> <!-- <servlet-class>com.onlineshop.servlet.LoginServlet</servlet-class>--> <!-- </servlet>--> <!-- <servlet>--> <!-- <servlet-name>RegisterServlet</servlet-name>--> <!-- <servlet-class>com.example.onlineshop.servlet.RegisterServlet</servlet-class>--> <!-- </servlet>--> <!-- <!– Servlet 映射 –>--> <!-- <servlet-mapping>--> <!-- <servlet-name>LoginServlet</servlet-name>--> <!-- <url-pattern>/login_process.jsp</url-pattern>--> <!-- </servlet-mapping>--> <!-- <servlet-mapping>--> <!-- <servlet-name>RegisterServlet</servlet-name>--> <!-- <url-pattern>/register_process.jsp</url-pattern>--> <!-- </servlet-mapping>--> <!-- <!– 错误页面配置 –>--> <!--<!– <error-page>–>--> <!--<!– <error-code>404</error-code>–>--> <!--<!– <location>/error/404.jsp</location>–>--> <!--<!– </error-page>–>--> <!--<!– <error-page>–>--> <!--<!– <error-code>500</error-code>–>--> <!--<!– <location>/error/500.jsp</location>–>--> <!--<!– </error-page>–>--> <!-- <!– 上下文参数 –>--> <!-- <context-param>--> <!-- <param-name>jdbcDriver</param-name>--> <!-- <param-value>com.mysql.jdbc.Driver</param-value>--> <!-- </context-param>--> <!-- <context-param>--> <!-- <param-name>jdbcUrl</param-name>--> <!-- <param-value>jdbc:mysql://localhost:3306/onlineshop</param-value>--> <!-- </context-param>--> <!-- <!– 过滤器配置(可选) –>--> <!--<!– <filter>–>--> <!--<!– <filter-name>CharacterEncodingFilter</filter-name>–>--> <!--<!– <filter-class>com.example.onlineshop.filter.CharacterEncodingFilter</filter-class>–>--> <!--<!– <init-param>–>--> <!--<!– <param-name>encoding</param-name>–>--> <!--<!– <param-value>UTF-8</param-value>–>--> <!--<!– </init-param>–>--> <!--<!– </filter>–>--> <!--<!– <filter-mapping>–>--> <!--<!– <filter-name>CharacterEncodingFilter</filter-name>–>--> <!--<!– <url-pattern>/*</url-pattern>–>--> <!--<!– </filter-mapping>–>--> </web-app>我这个配置有问题吗
06-16
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@ page import="javax.servlet.*,java.text.*" %> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="renderer" content="webkit"> <title>收入综合分析平台</title> <link rel="stylesheet" href="${pageContext.request.contextPath}/resources/bootstrap-3.3.7-dist/css/bootstrap.min.css"> <%-- 右击菜单样式 --%> <link href="${pageContext.request.contextPath}/resources/ruoyi/ruoyi/css/jquery.contextMenu.min.css" rel="stylesheet"/> <%-- <link href="${pageContext.request.contextPath}/resources/ruoyi/ruoyi/css/animate.min.css" rel="stylesheet"/>--%> <link href="${pageContext.request.contextPath}/resources/ruoyi/ruoyi/css/style.min.css" rel="stylesheet"/> <link href="${pageContext.request.contextPath}/resources/ruoyi/ruoyi/css/skins.css" rel="stylesheet"/> <link href="${pageContext.request.contextPath}/resources/ruoyi/ruoyi/css/ry-ui.css?v=4.6.1" rel="stylesheet"/> <%-- 图标库 --%> <link href="${pageContext.request.contextPath}/resources/ruoyi/ruoyi/css/font-awesome.min.css" rel="stylesheet"/> <script src="${pageContext.request.contextPath}/resources/js/jquery-1.11.3.min.js?v=<%=System.currentTimeMillis()%>"></script> <script src="${pageContext.request.contextPath}/resources/bootstrap-3.3.7-dist/js/bootstrap.min.js?v=<%=System.currentTimeMillis()%>"></script> <script src="${pageContext.request.contextPath}/resources/global/global.js?v=<%=System.currentTimeMillis()%>"></script> <script type="text/javascript"> $(function(){ $.ajax({ type: 'get', url: "dic/getUrlByUser", async: false, dataType: 'json', success: function (data) {//返回list数据并循环获取 var ht = ""; var arr = ['desktop','calculator','leanpub','map','send','bar-chart','line-chart','train','american-sign-language-interpreting','gears','user-circle-o','paper-plane','firefox']; for(var i=0;i<data.length;i++){ //循环一级菜单 ht = ht +'<li>'+ '<a href="#">' + '<i class="fa fa-'+arr[i]+'"></i> ' + '<span class="nav-label">'+data[i].mkName+'</span>' + '<span class="fa arrow"></span>' + '</a>'+ '<ul class="nav nav-second-level collapse">'; var obj = data[i].obj; if(obj[0].cdlb == ""){//该模块不存在二级菜单 for(var j=0;j<obj.length;j++){ ht = ht + '<li>\n' + '<a class="menuItem" href="'+obj[j].cdUrl+'">'+ obj[j].cdName +'</a>' + '</li>'; } ht = ht + '</ul></li>'; }else{ var cdlbArr = new Array(); for(var j=0;j<obj.length;j++){ cdlbArr.push(obj[j].cdlb); } cdlbArr = uniqueArr(cdlbArr); for(var k=0;k<cdlbArr.length;k++){ ht = ht + '<li>\n' + '<a href="#"><i class="fa fa-pied-piper"></i> '+cdlbArr[k]+'<span class="fa arrow"></span></a>\n' + '<ul class="nav nav-third-level collapse">'; for(var m=0;m<obj.length;m++){ if(cdlbArr[k] == obj[m].cdlb){ ht = ht + '<li>\n' + '<a class="menuItem" href="'+obj[m].cdUrl+'">'+ obj[m].cdName +'</a>' + '</li>'; } } ht = ht + '</ul></li>'; } } ht = ht + '</ul></li>'; } $("#side-menu").append(ht); } }); }) /* * 用于解决浏览器关闭后Cookie未失效,攻击者可在用户关闭浏览器后,通过同一cookie直接访问网站(无需重新登录),窃取用户会话; * 由于ajax是异步 使用时会造成发送不过去的现象 需要使用同步请求 * 另外 如果只是使用 window.addEventListener('beforeunload'来判断 会出现 刷野也会消除session 所以只能通过一下方法来实现 * */ window.addEventListener('beforeunload', function(e) { // 获取导航类型(替代废弃的performance.navigation.type) console.log(JSON.stringify(performance.getEntriesByType("navigation")[0].toJSON().type)) const navType = performance.getEntriesByType("navigation")[0].toJSON().type; sendLogoutRequest(navType) // 排除刷新行为,仅在离开/关闭时触发逻辑 if (navType !== 'reload') { console.log('离开页面,执行逻辑') //sendLogoutRequest() return '111'; } }); /*class PageLeaveHandler { constructor() { this.isRefreshing = false; this.pendingUnload = false; this.pendingUnloadnum = 0;//默认值 this.init(); } init() { // 监听刷新快捷键 window.addEventListener('keydown', (e) => { if (e.key === 'F5' || (e.ctrlKey && e.key === 'F5')) { this.isRefreshing = true; } }); // 监听beforeunload事件 window.addEventListener('beforeunload', this.handleBeforeUnload.bind(this)); } handleBeforeUnload(e) { if (this.isRefreshing) { this.pendingUnload = false; return; } //sendLogoutRequest(this.isRefreshing) this.pendingUnload = true; return 1; } } new PageLeaveHandler();*/ function sendLogoutRequest(navType) { const logoutUrl = '${pageContext.request.contextPath}/sys/loginoutall?navType='+navType; if (navigator.sendBeacon) { navigator.sendBeacon(logoutUrl, 'loginoutall'); } else { const xhr = new XMLHttpRequest(); xhr.open('GET', logoutUrl, false); // 同步请求 xhr.timeout = 2000; try { xhr.send(); } catch (e) { // 忽略错误 } } } /*window.addEventListener('beforeunload', function(e) { // 取消事件的默认行为(部分浏览器需要) e.preventDefault(); if(!e.isTrusted){ // 2. 拼接正确的上下文路径(关键:避免404) const logoutUrl = '${pageContext.request.contextPath}/sys/loginoutall'; // 3. 用sendBeacon发送请求,浏览器会优先保证发送完成 if (navigator.sendBeacon) { navigator.sendBeacon(logoutUrl, 'loginoutall'); } else { const xhr = new XMLHttpRequest(); xhr.open('GET', logoutUrl, false); // 同步请求 xhr.timeout = 2000; try { xhr.send(); } catch (e) { } } } });*/ </script> </head> <body class="fixed-sidebar full-height-layout gray-bg skin-blue theme-light" style="overflow: hidden"> <div id="wrapper"> <!--左侧导航开始--> <nav class="navbar-default navbar-static-side" role="navigation"> <div class="nav-close"> <i class="fa fa-times-circle"></i> </div> <a href=""> <li class="logo hidden-xs"> <span class="logo-lg">欢迎${user.username}</span> </li> </a> <div class="sidebar-collapse"> <ul class="nav" id="side-menu"> <li> <div class="user-panel"> <%-- 该位置换谁个人中心地址 --%> <a class="menuItem noactive" title="个人中心" href=""> <div class="hide" text="个人中心"></div> <div class="pull-left image"> <%--<img src="resources/ruoyi/favicon.ico" class="img-circle" alt="User Image">--%> <img src="resources/image/eee.png" class="img-circle" alt="User Image"> </div> </a> <div class="pull-left info"> <%-- 该位置可以加上el表达式 然后读取成登录名即可 --%> <p></p> <a href="#"><i class="fa fa-circle text-success"></i> 在线</a> <%-- 该位置发起退出请求 换上即可 --%> <a href="sys/loginout" style="padding-left:5px;"><i class="fa fa-sign-out text-danger"></i> 注销</a> </div> </div> </li> <li> <a class="menuItem" href="web/main/sy.jsp"><i class="fa fa-home"></i> <span class="nav-label">首页</span></a> </li> </ul> </div> </nav> <!--左侧导航结束--> <!--右侧部分开始--> <div id="page-wrapper" class="gray-bg dashbard-1"> <div class="row border-bottom"> <nav class="navbar navbar-static-top" role="navigation" style="margin-bottom: 0"> <div class="navbar-header"> <a class="navbar-minimalize minimalize-styl-2" style="color:#FFF;" href="#" title="收起菜单"> <i class="fa fa-bars"></i> </a> </div> <ul class="nav navbar-top-links navbar-right welcome-message"> <%--<li><a data-toggle="tooltip" data-trigger="hover" data-placement="bottom" title="开发文档" href="http://doc.ruoyi.vip/ruoyi" target="_blank"><i class="fa fa-question-circle"></i> 文档</a></li> <li><a data-toggle="tooltip" data-trigger="hover" data-placement="bottom" title="锁定屏幕" href="#" id="lockScreen"><i class="fa fa-lock"></i> 锁屏</a></li>--%> <li><a data-toggle="tooltip" data-trigger="hover" data-placement="bottom" title="全屏显示" href="#" id="fullScreen"><i class="fa fa-arrows-alt"></i> 全屏</a></li> <%--<li class="dropdown user-menu"> <a href="javascript:void(0)" class="dropdown-toggle" data-hover="dropdown"> <img src="resources/image/eee.png" class="user-image"> <%– 该位置用el表达式读取登录名 –%> <span class="hidden-xs">海来怡天</span> </a> <ul class="dropdown-menu"> <li class="mt5"> <%– 该位置是个人中心超链接 –%> <a href="" class="menuItem noactive"> <i class="fa fa-user"></i> 个人中心</a> </li> <li> <a onclick="resetPwd()"> <i class="fa fa-key"></i> 修改密码</a> </li> <li> <a onclick="switchSkin()"> <%–<a id="btn" >–%> <i class="fa fa-dashboard"></i> 切换主题 </a> </li> <li class="divider"></li> <li> <%– 该位置是推出登录请求 –%> <a href=""> <i class="fa fa-sign-out"></i> 退出登录</a> </li> </ul> </li>--%> </ul> </nav> </div> <div class="row content-tabs"> <button class="roll-nav roll-left tabLeft"> <i class="fa fa-backward"></i> </button> <nav class="page-tabs menuTabs"> <div class="page-tabs-content"> <a href="javascript:" class="active menuTab" data-id="web/main/sy.jsp">首页</a> </div> </nav> <button class="roll-nav roll-right tabRight"> <i class="fa fa-forward"></i> </button> <a href="javascript:void(0);" class="roll-nav roll-right tabReload"><i class="fa fa-refresh"></i> 刷新</a> </div> <a id="ax_close_max" class="ax_close_max" href="#" title="关闭全屏"> <i class="fa fa-times-circle-o"></i> </a> <div class="row mainContent" id="content-main" > <iframe class="RuoYi_iframe" name="iframe0" width="100%" height="100%" data-id="web/main/sy.jsp" src="web/main/sy.jsp" frameborder="0" seamless></iframe> </div> </div> <!--右侧部分结束--> </div> <!-- 全局js --> <script type="text/javascript" src="${pageContext.request.contextPath}/resources/ruoyi/js/plugins/metisMenu/jquery.metisMenu.js?v=<%=System.currentTimeMillis()%>"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/resources/ruoyi/js/plugins/slimscroll/jquery.slimscroll.min.js?v=<%=System.currentTimeMillis()%>"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/resources/ruoyi/js/jquery.contextMenu.min.js?v=<%=System.currentTimeMillis()%>"></script> <%--<script src="${pageContext.request.contextPath}/resources/ruoyi/ajax/libs/layui/layui.js?v=<%=System.currentTimeMillis()%>"></script>--%> <%-- 该方法用于将页面加载到本页面 --%> <script type="text/javascript" src="${pageContext.request.contextPath}/resources/ruoyi/ajax/libs/blockUI/jquery.blockUI.js?v=<%=System.currentTimeMillis()%>"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/resources/ruoyi/ajax/libs/layer/layer.min.js?v=<%=System.currentTimeMillis()%>"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/resources/ruoyi/ruoyi/js/ry-ui.js?v=<%=System.currentTimeMillis()%>"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/resources/ruoyi/ruoyi/js/common.js?v=<%=System.currentTimeMillis()%>"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/resources/ruoyi/ruoyi/index.js?v=<%=System.currentTimeMillis()%>"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/resources/ruoyi/ajax/libs/fullscreen/jquery.fullscreen.js?v=<%=System.currentTimeMillis()%>"></script> <script> /*window.history.forward(1); var ctx = "/zhfx"; // 皮肤缓存 var skin = storage.get("skin");*/ // history(表示去掉地址的#)否则地址以"#"形式展示 var mode = "history"; // 历史访问路径缓存 var historyPath = storage.get("historyPath"); // 是否页签与菜单联动 var isLinkage = true; /* * 这个js如果删了 按下F12编辑时 页面会不起作用 * */ $(function() { var lockPath = storage.get('lockPath'); if($.common.equals("history", mode) && window.performance.navigation.type == 1) { var url = storage.get('publicPath'); if ($.common.isNotEmpty(url)) { applyPath(url); } } else if($.common.isNotEmpty(lockPath)) { applyPath(lockPath); storage.remove('lockPath'); } else { var hash = location.hash; if ($.common.isNotEmpty(hash)) { var url = hash.substring(1, hash.length); applyPath(url); } else { if($.common.equals("history", mode)) { storage.set('publicPath', ""); } } } $("[data-toggle='tooltip']").tooltip(); }); </script> </body> </html> 为什么 一个刷新 一个跳转 这俩 点刷新是reload 再点跳转还是reload 必须第二下才是navigate 但是这样点了navigate之后 再点刷新还是navigate 必须再点刷新才是reload 这可不能这样
11-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值