- ThreadLocal 在 Spring 与数据库交互中的应用笔记
笑衬人心。
JAVA学习笔记数据库spring笔记
一、基本概念1.1什么是ThreadLocal?ThreadLocal是Java提供的一个线程本地存储工具类。每个线程访问ThreadLocal时,都只能看到自己线程范围内的变量副本,线程之间互不影响。常用于保存线程上下文信息,如用户登录信息、事务状态、数据库连接等。ThreadLocalthreadLocal=newThreadLocal>resources=newNamedThreadLoca
- Java 领域 MyBatis 与数据库连接池的搭配使用
Java技术栈实战
javamybatis数据库ai
Java领域MyBatis与数据库连接池的搭配使用关键词:MyBatis、数据库连接池、Java持久层、性能优化、Druid、HikariCP、Spring集成摘要:本文深入探讨Java领域中MyBatis框架与数据库连接池的搭配使用原理和实践。文章从基础概念入手,详细分析MyBatis的工作原理和数据库连接池的核心机制,重点讲解两者如何协同工作以提升应用性能。通过源码解析、性能对比和实际项目案例
- Spring Boot基础
小李是个程序
springboot后端java
5.SpringBoot配置解析5.1.基础服务端口:server.port=8080(应用启动后监听8080端口)应用名称:spring.application.name=Chat64(注册到服务发现等场景时的标识)5.2.数据库连接(MySQL)URL:jdbc:mysql://localhost:3306/ai-chat(连接本地3306端口的ai-chat数据库,含时区、编码等参数)驱动:
- Navicat数据库管理工具安装与应用教程
Matthew Um
本文还有配套的精品资源,点击获取简介:Navicat是一款支持多种数据库系统的管理工具,具备统一工作环境、优化的数据库连接和操作界面,极大地提高了数据库管理员和开发者的效率。该软件支持MySQL、Oracle等多种数据库类型,并为这些数据库提供了一系列管理与开发功能,如数据同步、性能分析、SQL查询等。用户可以下载Navicat的安装包,通过简单的安装过程后,即可使用其丰富的功能来高效管理数据库。
- mysql连接池
池化技术池化技术能够减少资源对象的创建次数,提高程序的响应性能,特别是在高并发情况下,这种提高更加明显。共同特征池化技术通常应用于以下对象,这些对象具有以下共同特征:对象创建时间长创建对象需要较长的时间。对象创建需要大量资源包括内存、CPU或网络资源。对象创建后可被重复使用通过复用的方式提高效率,避免重复创建。数据库连接池数据库连接池(ConnectionPooling)是一种优化数据库连接管理的
- 线程池/内存池/mysql连接池
目录线程池介绍1.线程池的组成部分2.线程池的线程数量确定3.线程池的应用场景4.线程池的工作原理5.线程池的接口设计6.线程池的数据结构设计7.具体线程池的代码实现如下内存池的介绍1.内存池的定义2.内存池的作用3.内存池的实现原理4.内存池的应用场景mysql连接池1.课程介绍和池化技术概述2.数据库连接池的概念和作用3.数据库连接的定义和特性4.请求回应模式和数据库访问模式5.高并发处理和M
- Python 操作MySQL数据库
目录Python连接MySQL1.概述2.核心作用3.核心流程(以PyMySQL为例)4.重点总结5.典型应用场景一、安装PythonMySQL连接库1.安装mysql-connector-python2.安装PyMySQL二、Python连接MySQL数据库1.导入连接库2.创建数据库连接3.创建游标对象4.执行SQL语句5.获取查询结果6.关闭连接三、常见的MySQL操作1.插入数据(INSE
- spring-data-jpa+spring+hibernate+druid配置
参考链接:http://doc.okbase.net/liuyitian/archive/109276.htmlhttp://my.oschina.net/u/1859292/blog/312188最新公司的web项目需要用到spring-data-jpa作为JPA的实现框架,同时使用阿里巴巴的开源数据库连接池druid。关于这两种框架的介绍我在这里就不多赘述。直接进入配置页面:spring的配置
- FastAPI依赖注入:构建高可维护API的核心理念与实战
源滚滚AI编程
fastapilog4j
依赖注入(DependencyInjection,DI)作为FastAPI的核心设计模式,通过解耦组件依赖关系、提升代码复用性和可测试性,已成为现代API开发的基石。本文将深入解析其工作原理、高级特性及企业级应用场景。一、依赖注入的核心价值解耦与模块化将数据库连接、认证逻辑等基础设施与业务逻辑分离,避免代码冗余。示例:路由函数无需手动创建数据库连接,通过Depends(get_db)自动注入[ci
- 关于ideamaven打包报错
小抠的菜鸟之路
#packagemaven
关于使用idea打包的时候报错,下面记录一下我一个上午遇到的三个问题1.Error:(171,64)java:�Ҳ�������Error:(171,64)java:�Ҳ�������一般出现这种方框框里带问号的图标或者字体,我们一般判定为乱码行为,java,sql都是这样,vue还不清楚,目前使用的还少,还没有出现这种问题,所以过来记录一下,sql问题可以在数据库连接工具中去设置一下字符集,当然
- 【MyBatis连接池全揭秘】内嵌POOLED实现原理与性能调优全攻略
你是否好奇MyBatis如何高效管理数据库连接?为什么连接池能提升数倍性能?本文将深入剖析MyBatis自带连接池POOLED的实现原理,带你掌握企业级性能调优技巧!一、连接池:数据库性能的倍增器1.没有连接池的世界应用程序数据库创建连接返回连接执行SQL关闭连接每次操作都经历TCP三次握手、身份验证等开销!应用程序数据库痛点:频繁创建/关闭连接消耗70%以上时间!2.连接池的价值请求1连接池请求
- C#配置全面详解:从传统方式到现代配置系统
阿蒙Armon
C#工作中的应用c#网络数据库
C#配置全面详解:从传统方式到现代配置系统在软件开发中,配置是指应用程序运行时可调整的参数集合,如数据库连接字符串、API地址、日志级别等。将这些参数从代码中分离出来,便于在不修改代码的情况下调整应用行为。C#提供了多种配置管理方式,从传统的XML配置文件到现代的多源配置系统,每种方式都有其适用场景。本文将全面介绍C#中的配置技术,帮助开发者根据项目需求选择合适的配置方案。一、配置基础与核心概念1
- 微服务分布式配置中心详解
一、分布式配置中心概述在微服务架构中,随着服务数量的增多和复杂度的提升,配置管理变得至关重要。分布式配置中心应运而生,它专门用于管理微服务架构中的配置文件。以支持Go语言的viper为例,配置文件管理涵盖了增加、修改、删除配置项等操作,同时要实现配置项在测试、开发和生产环境的隔离。不同环境的配置可能存在差异,例如数据库连接地址、日志级别等,因此需要对这些配置进行有效的管理和区分。二、本地文件配置的
- Python魔法:用@contextmanager简化上下文管理器
告别样板代码,用生成器优雅管理资源在Python开发中,上下文管理器是管理资源(如文件、数据库连接)的利器。传统的实现方法需要创建一个类并定义__enter__和__exit__两个方法,但Python的contextlib模块提供了更简洁的解决方案——@contextmanager装饰器。传统上下文管理器的实现痛点传统方式需要完整定义一个类,包含__enter__和__exit__方法:clas
- PyMySQL:高级用法全解析
在数据驱动的时代,数据库操作是软件开发中至关重要的一环。PyMySQL作为Python中操作MySQL数据库的一个强大库,为开发者提供了便捷高效的数据库交互方式。在这篇博客中,我们将深入探讨PyMySQL的高级用法,带你领略其强大之处。一、连接池的构建与使用在实际应用中,频繁地创建和销毁数据库连接是非常耗时且低效的。连接池的出现就是为了解决这个问题。以下是使用PyMySQL构建连接池的示例:imp
- C#编写的SQL Server数据库配置工具源码
韦先波
本文还有配套的精品资源,点击获取简介:《SQLServerConfiguration_C#_exe.execom.exe_源码》是一个C#编写的工具,用于管理SQLServer数据库连接和用户表操作。它允许用户直接通过图形界面进行数据库连接和交互,而无需深入了解SQL语句。工具包含了一个可执行文件execom.exe,可以实现无需额外编译的直接运行。用户可通过界面选择数据库,执行用户表的相关操作,
- HYTop.mdb解压工具:MDB文件自动化处理
本文还有配套的精品资源,点击获取简介:HYTop.mdb解压工具是一款处理MicrosoftAccess默认格式MDB数据库文件的实用工具。它能够帮助用户在空间压缩后进行解压操作,并支持网站打包流程的自动化启动。工具的主要功能是恢复压缩数据至原始状态,确保文件的完整性和安全性,在网络传输和服务器存储过程中发挥作用。此外,它还能自动化进行文件解压、配置调整和数据库连接验证等部署步骤,简化网站部署流程
- (转)java.sql包介绍
数据库连接包:实现JDBC的类库;DriverManager类此类用于装载驱动程序,它所有的成员都是静态成员,所以在程序中无须对它进行实例化,直接通过类名就可以访问它。DriverManager类是JDBC的管理层,作用于用户和驱动程序间加载驱动程序Class.forName(“公司名.数据库名.驱动程序名”)如:Class.forName(“sun.jdbc.odbc.jdbcOdbcDrive
- php pgsql 连接池,PostgreSQL数据库连接池PgBouncer的搭建
weixin_39612499
phppgsql连接池
最近有些项目我们是采用PostgreSQL进行后端数据库,由于要对客户端的连接使用类型和连接数进行控制,因此我们采用PgBouncer来进行最近有些项目我们是采用PostgreSQL进行后端数据库,由于要对客户端的连接使用类型和连接数进行控制,因此我们采用PgBouncer来进行实施。PgBouncer相关的基本文档pgsqldb中文站已经有不少文档,这里我就不再作过多的说明,我将集中对其中的几个
- thinkphp5.0项目配置多MySQL数据库连接
thinkphp5mysql
公司项目需要连接2个MySQL数据库背景介绍:公司项目是基于fastadmin1.4.0.20230711开发的,里面用到的thinkphp版本是5.0.25,项目涉及到小程序端和设备端,之前做的是两个项目,但是部署在同一台服务器上,分别对应两个数据库,之前两个项目之间的交互是通过互相调用对方接口的方式实现的,优化的时候就想通过在一个项目中连接两个MySQL数据库的方式,避免互相调用带来的性能开销
- JDBC连接池
今惜时
JDBC数据库javamysql
数据库连接池什么是连接池连接池是创建和管理一个连接的缓冲池的技术,这些连接准备好被任何需要它们的线程使用。这种连接“汇集”起来的技术基于这样的一个事实:对于大多数应用程序,当它们正在处理通常需要数毫秒完成的事务时,仅需要能够访问JDBC连接的1个线程。当不处理事务时,这个连接就会闲置。相反,连接池允许闲置的连接被其它需要的线程使用。事实上,当一个线程需要用JDBC对一个GBase或其它数据库操作时
- 数据库连接池的作用是什么?
破碎的天堂鸟
学习教程数据库oraclesql
数据库连接池(DatabaseConnectionPool)是一种核心的数据库资源管理技术,通过预先创建、复用和管理数据库连接,显著提升应用程序的性能、稳定性和资源利用率。其作用可归纳为以下核心维度:一、核心作用:提升系统性能与效率减少连接创建/销毁开销数据库连接的建立涉及TCP三次握手、身份验证、内存分配等操作,耗时约数十至数百毫秒。连接池在初始化时创建固定数量的连接(如minIdle),后续请
- 设计模式 简单汇总
花王江不语
设计模式设计模式
设计模式是软件工程中广泛使用的一套解决方案,用于解决常见问题并提高代码的质量。它们分为创建型、结构型和行为型三类,共23种模式。以下是各类别及其常见模式的详细说明:目录创建型模式结构型模式行为型模式创建型模式这些模式关注对象的创建机制,帮助控制实例化过程。单例模式(Singleton):确保一个类只有一个实例,并提供全局访问点。应用场景:数据库连接管理、缓存系统等,避免资源浪费和潜在冲突。工厂方法
- PostgreSQL连接池监控与优化:pg_stat_activity详解及连接阻塞排查指南
1.引言PostgreSQL是一款功能强大的开源关系型数据库,广泛应用于各类企业级应用。在高并发场景下,数据库连接池的管理和监控至关重要。如果连接池使用不当,可能会导致连接泄漏、阻塞甚至数据库崩溃。本文将详细介绍如何使用pg_stat_activity监控PostgreSQL连接状态,并针对连接卡住、阻塞等问题提供解决方案。2.使用pg_stat_activity监控连接状态pg_stat_act
- ThreadLocal
(七)ThreadLocalThreadLocal是Java中用于实现线程局部变量的类,它为每个使用该变量的线程都创建一个独立的副本,每个线程都可以独立地改变自己的副本,而不会影响其他线程所对应的副本。以下是关于ThreadLocal的详细解析:1.核心概念线程隔离:每个线程都拥有自己的独立变量副本,线程间互不影响。存储作用域:变量的作用域限定于当前线程,生命周期与线程一致。典型场景:数据库连接(
- spring boot 之 集成 druid数据库连接池
我叫晨曦啊
springbootspringboot数据库后端
springboot版本:2.3.12.RELEASEMySQL版本:8.0Druid简介Druid是阿里开源的一个数据库连接池和SQL查询优化工具,用于提高应用程序对数据库的性能和可扩展性。主要提供的功能:数据库连接池、数据库连接池监控、SQL查询优化、数据源管理、防御SQL注入、统计和监控。引入pom依赖com.alibabadruid-spring-boot-starter1.2.16com
- MySQL(116)如何监控负载均衡状态?
辞暮尔尔-烟火年年
MySQLmysql负载均衡数据库
监控负载均衡器的状态对于确保系统的正常运行至关重要。以下是如何在应用程序级别和使用HAProxy进行负载均衡时进行监控的详细方法。我们将分别介绍SpringBoot和HAProxy的监控方法。一.应用程序级别的负载均衡监控在SpringBoot中,监控数据库连接池和数据源的状态是监控负载均衡状态的一部分。我们可以使用SpringBootActuator和一些额外的配置来实现这一点。1.添加Spri
- 详细说说线程的同步和互斥
牛马baby
多线程面试资料
面试资料大全|各种技术资料-2000GJava中线程的同步(Synchronization)和互斥(MutualExclusion)这两个核心并发概念。它们是确保多线程程序正确性、避免竞态条件(RaceCondition)和维持数据一致性的基石。核心目标:协调多个线程对共享资源(变量、对象、文件、数据库连接等)的访问,防止它们同时进行可能导致数据损坏或逻辑错误的操作。1.互斥(MutualExcl
- Python Web应用开发之Flask框架——高级应用(一)
Smile丶Life丶
Pythonpython前端flask
八、上下文管理在Flask框架中,上下文管理是一项关键特性,它允许开发者在应用程序的不同部分之间共享数据,并且确保在请求处理期间相关的资源(如数据库连接)能够正确地初始化和清理。Flask中有两种主要的上下文类型:应用上下文(appcontext)和请求上下文(requestcontext)。8.1请求上下文在Flask中,请求上下文是一个关键概念,它包含了处理请求所需的所有信息。当Flask接收
- OracleSync2MySQL 数据同步问题bad connection、创建表异常、数据映射异常
aspirant-complete
运维开发
1、mysql数据库连接badconnection、invalidconnection等异常检查数据库连接空闲时间MySQL服务器等待一个连接所允许的空闲时间。如果达到此时间,MySQL服务器将自动关闭该连接,除非该连接正在活动状态```sqlSHOWVARIABLESLIKE'wait_timeout';
python manage.py makemigrations polls
说明:polls 是你的应用名字,运行该命令时需要根据你的应用名字进行调整
查看该次迁移需要执行的 SQL 语句(只查看语句,并不应用到数据库上):
python manage.p
- 阶乘算法之一N! 末尾有多少个零
周凡杨
java算法阶乘面试效率
&n
- spring注入servlet
g21121
Spring注入
传统的配置方法是无法将bean或属性直接注入到servlet中的,配置代理servlet亦比较麻烦,这里其实有比较简单的方法,其实就是在servlet的init()方法中加入要注入的内容:
ServletContext application = getServletContext();
WebApplicationContext wac = WebApplicationContextUtil
- Jenkins 命令行操作说明文档
510888780
centos
假设Jenkins的URL为http://22.11.140.38:9080/jenkins/
基本的格式为
java
基本的格式为
java -jar jenkins-cli.jar [-s JENKINS_URL] command [options][args]
下面具体介绍各个命令的作用及基本使用方法
1. &nb
- UnicodeBlock检测中文用法
布衣凌宇
UnicodeBlock
/** * 判断输入的是汉字 */ public static boolean isChinese(char c) { Character.UnicodeBlock ub = Character.UnicodeBlock.of(c);
- java下实现调用oracle的存储过程和函数
aijuans
javaorale
1.创建表:STOCK_PRICES
2.插入测试数据:
3.建立一个返回游标:
PKG_PUB_UTILS
4.创建和存储过程:P_GET_PRICE
5.创建函数:
6.JAVA调用存储过程返回结果集
JDBCoracle10G_INVO
- Velocity Toolbox
antlove
模板toolboxvelocity
velocity.VelocityUtil
package velocity;
import org.apache.velocity.Template;
import org.apache.velocity.app.Velocity;
import org.apache.velocity.app.VelocityEngine;
import org.apache.velocity.c
- JAVA正则表达式匹配基础
百合不是茶
java正则表达式的匹配
正则表达式;提高程序的性能,简化代码,提高代码的可读性,简化对字符串的操作
正则表达式的用途;
字符串的匹配
字符串的分割
字符串的查找
字符串的替换
正则表达式的验证语法
[a] //[]表示这个字符只出现一次 ,[a] 表示a只出现一
- 是否使用EL表达式的配置
bijian1013
jspweb.xmlELEasyTemplate
今天在开发过程中发现一个细节问题,由于前端采用EasyTemplate模板方法实现数据展示,但老是不能正常显示出来。后来发现竟是EL将我的EasyTemplate的${...}解释执行了,导致我的模板不能正常展示后台数据。
网
- 精通Oracle10编程SQL(1-3)PLSQL基础
bijian1013
oracle数据库plsql
--只包含执行部分的PL/SQL块
--set serveroutput off
begin
dbms_output.put_line('Hello,everyone!');
end;
select * from emp;
--包含定义部分和执行部分的PL/SQL块
declare
v_ename varchar2(5);
begin
select
- 【Nginx三】Nginx作为反向代理服务器
bit1129
nginx
Nginx一个常用的功能是作为代理服务器。代理服务器通常完成如下的功能:
接受客户端请求
将请求转发给被代理的服务器
从被代理的服务器获得响应结果
把响应结果返回给客户端
实例
本文把Nginx配置成一个简单的代理服务器
对于静态的html和图片,直接从Nginx获取
对于动态的页面,例如JSP或者Servlet,Nginx则将请求转发给Res
- Plugin execution not covered by lifecycle configuration: org.apache.maven.plugin
blackproof
maven报错
转:http://stackoverflow.com/questions/6352208/how-to-solve-plugin-execution-not-covered-by-lifecycle-configuration-for-sprin
maven报错:
Plugin execution not covered by lifecycle configuration:
- 发布docker程序到marathon
ronin47
docker 发布应用
1 发布docker程序到marathon 1.1 搭建私有docker registry 1.1.1 安装docker regisry
docker pull docker-registry
docker run -t -p 5000:5000 docker-registry
下载docker镜像并发布到私有registry
docker pull consol/tomcat-8.0
- java-57-用两个栈实现队列&&用两个队列实现一个栈
bylijinnan
java
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
/*
* Q 57 用两个栈实现队列
*/
public class QueueImplementByTwoStacks {
private Stack<Integer> stack1;
pr
- Nginx配置性能优化
cfyme
nginx
转载地址:http://blog.csdn.net/xifeijian/article/details/20956605
大多数的Nginx安装指南告诉你如下基础知识——通过apt-get安装,修改这里或那里的几行配置,好了,你已经有了一个Web服务器了。而且,在大多数情况下,一个常规安装的nginx对你的网站来说已经能很好地工作了。然而,如果你真的想挤压出Nginx的性能,你必
- [JAVA图形图像]JAVA体系需要稳扎稳打,逐步推进图像图形处理技术
comsci
java
对图形图像进行精确处理,需要大量的数学工具,即使是从底层硬件模拟层开始设计,也离不开大量的数学工具包,因为我认为,JAVA语言体系在图形图像处理模块上面的研发工作,需要从开发一些基础的,类似实时数学函数构造器和解析器的软件包入手,而不是急于利用第三方代码工具来实现一个不严格的图形图像处理软件......
&nb
- MonkeyRunner的使用
dai_lm
androidMonkeyRunner
要使用MonkeyRunner,就要学习使用Python,哎
先抄一段官方doc里的代码
作用是启动一个程序(应该是启动程序默认的Activity),然后按MENU键,并截屏
# Imports the monkeyrunner modules used by this program
from com.android.monkeyrunner import MonkeyRun
- Hadoop-- 海量文件的分布式计算处理方案
datamachine
mapreducehadoop分布式计算
csdn的一个关于hadoop的分布式处理方案,存档。
原帖:http://blog.csdn.net/calvinxiu/article/details/1506112。
Hadoop 是Google MapReduce的一个Java实现。MapReduce是一种简化的分布式编程模式,让程序自动分布到一个由普通机器组成的超大集群上并发执行。就如同ja
- 以資料庫驗證登入
dcj3sjt126com
yii
以資料庫驗證登入
由於 Yii 內定的原始框架程式, 採用綁定在UserIdentity.php 的 demo 與 admin 帳號密碼: public function authenticate() { $users=array( &nbs
- github做webhooks:[2]php版本自动触发更新
dcj3sjt126com
githubgitwebhooks
上次已经说过了如何在github控制面板做查看url的返回信息了。这次就到了直接贴钩子代码的时候了。
工具/原料
git
github
方法/步骤
在github的setting里面的webhooks里把我们的url地址填进去。
钩子更新的代码如下: error_reportin
- Eos开发常用表达式
蕃薯耀
Eos开发Eos入门Eos开发常用表达式
Eos开发常用表达式
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2014年8月18日 15:03:35 星期一
&
- SpringSecurity3.X--SpEL 表达式
hanqunfeng
SpringSecurity
使用 Spring 表达式语言配置访问控制,要实现这一功能的直接方式是在<http>配置元素上添加 use-expressions 属性:
<http auto-config="true" use-expressions="true">
这样就会在投票器中自动增加一个投票器:org.springframework
- Redis vs Memcache
IXHONG
redis
1. Redis中,并不是所有的数据都一直存储在内存中的,这是和Memcached相比一个最大的区别。
2. Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,hash等数据结构的存储。
3. Redis支持数据的备份,即master-slave模式的数据备份。
4. Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。
Red
- Python - 装饰器使用过程中的误区解读
kvhur
JavaScriptjqueryhtml5css
大家都知道装饰器是一个很著名的设计模式,经常被用于AOP(面向切面编程)的场景,较为经典的有插入日志,性能测试,事务处理,Web权限校验, Cache等。
原文链接:http://www.gbtags.com/gb/share/5563.htm
Python语言本身提供了装饰器语法(@),典型的装饰器实现如下:
@function_wrapper
de
- 架构师之mybatis-----update 带case when 针对多种情况更新
nannan408
case when
1.前言.
如题.
2. 代码.
<update id="batchUpdate" parameterType="java.util.List">
<foreach collection="list" item="list" index=&
- Algorithm算法视频教程
栏目记者
Algorithm算法
课程:Algorithm算法视频教程
百度网盘下载地址: http://pan.baidu.com/s/1qWFjjQW 密码: 2mji
程序写的好不好,还得看算法屌不屌!Algorithm算法博大精深。
一、课程内容:
课时1、算法的基本概念 + Sequential search
课时2、Binary search
课时3、Hash table
课时4、Algor
- C语言算法之冒泡排序
qiufeihu
c算法
任意输入10个数字由小到大进行排序。
代码:
#include <stdio.h>
int main()
{
int i,j,t,a[11]; /*定义变量及数组为基本类型*/
for(i = 1;i < 11;i++){
scanf("%d",&a[i]); /*从键盘中输入10个数*/
}
for
- JSP异常处理
wyzuomumu
Webjsp
1.在可能发生异常的网页中通过指令将HTTP请求转发给另一个专门处理异常的网页中:
<%@ page errorPage="errors.jsp"%>
2.在处理异常的网页中做如下声明:
errors.jsp:
<%@ page isErrorPage="true"%>,这样设置完后就可以在网页中直接访问exc