当前位置:首页 » 文件管理 » js全局缓存

js全局缓存

发布时间: 2023-03-25 04:10:57

‘壹’ js文件缓存到本地

对js文件进行hash,每次客户端请求的时候取回hash,如果缓存的js的hashcode与取回的hashcode不一致,则重新download脚本文件,否则不用。

‘贰’ 请问,有谁知道怎么全局缓存jsapi ticket的吗请大师指导

public class TokenSingleton
{
//缓存accessToken 的Map ,map中包含 accessToken jsapiticket 和 缓存的时间戳
//当然也可以分开成两个属性瞎散咯

private Dictionary<string, string> map = new Dictionary<渣神伍string, string>();

private TokenSingleton()
{
}

private static TokenSingleton single = null;

// 静态工厂方法
public static TokenSingleton getInstance()
{
if (single == null)
{
single = new TokenSingleton();
}
return single;
}

public Dictionary<string, string> getMap()
{
string time = map["time"];
string accessToken = map["access_token"];
string jsapiticket = map["jsapi_ticket"];
long nowDate = Framework.HttpHelper.HttpRequest.GetCurrentUinxTime();
if (accessToken != null && time != null && nowDate - long.Parse(time) < 3000 * 1000)
{
//alert("accessToken存在如或,且没有超时 , 返回单例");
}
else {
//alert("accessToken 超时 , 或者不存在 , 重新获取");
//获取access_token
string access_token = getAccessToken(appid, secret );
if (!string.IsNullOrEmpty(access_token))
{
map.Add("time", nowDate + "");
map.Add("access_token", access_token);

//获取jsapi_ticket
string jsapi_token = getJsapiTicket(access_token);
if (!string.IsNullOrEmpty(jsapi_token))
{
map.Add("jsapi_ticket", jsapi_token);
}
}
}
return map;
}

public void setMap(Dictionary<string, string> map)
{
this.map = map;
}

public static TokenSingleton getSingle()
{
return single;
}

public static void setSingle(TokenSingleton single)
{
TokenSingleton.single = single;
}

public string getAccessToken(string appid, string secret )
{
// 这个url链接地址和参数皆不能变
string url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appid + "&secret=" + secret;
string result = doHttpGet(url);

dynamic resultStr = JsonConvert.DeserializeObject(result, new { access_token = "", expires_in = "", errcode = "", errmsg = "" }.GetType());

//请求成功
if (resultStr != null && !string.IsNullOrWhiteSpace(resultStr.access_token))
{
return resultStr.access_token;
}
else
{
return "";
}
}

public string getJsapiTicket(string accessToken)
{
//获取jsapi_ticket
// 这个url链接地址和参数皆不能变
string url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=" + accessToken + "&type=jsapi";
string result = doHttpGet(url);
dynamic resultStr = JsonConvert.DeserializeObject(result, new { errcode = "", errmsg = "", ticket = "", expires_in = "" }.GetType());

//请求成功
if (resultStr.errcode == "0" && resultStr.errmsg == "ok")
{
return resultStr.ticket;
}
else
{
return "";
}
}

public static string doHttpGet(string url)
{
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
request.Method = "GET";
request.ContentType = "application/json";
request.Timeout = 1000 * 60 * 8;
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
if (response.StatusCode == HttpStatusCode.OK)
{
StreamReader reader = new StreamReader(response.GetResponseStream() ?? throw new InvalidOperationException(), Encoding.UTF8);
string result = reader.ReadToEnd();
response.Close();
return result;
}
else
{
response.Close();
return response.Headers.ToString();
}

}
public static long GetCurrentUinxTime()
{
DateTime currentDate = DateTime.Now;//当前时间
//转化为时间戳
DateTime localTime = new DateTime(1970, 1, 1, 8, 0, 0);//TimeZone.CurrentTimeZone.ToLocalTime(new DateTime(1970, 1, 1));
return long.Parse((currentDate - localTime).TotalSeconds.ToString().Split('.')[0]);
}
}

‘叁’ js缓存问题怎么解决

面对的缓存问题有两个:一是页面引入的JS文件缓存。二是JS请求后台的缓存。对于第一种情况,有两种处理方式:
1、可以在页面引入的JS文件后面增加日趋,如果不经常改动的文件,可以在每次改动后修改后缀。
2、对于第二种情况,一般的处理方式是在请求的路径后面加上毫秒值,这样每次请求的路径都不一样,但是对于后台来说都是一样的,用来欺骗浏览器,进行实时请求,不调用浏览器缓存。

‘肆’ 能用JS或者前端的什么方法实现清除浏览器缓存吗

可以用JS实现清除浏览器缓存,解决方法如下:

1、在静态页面也就是以.html,.jsp,.aspx,.php结尾的文件中在<dead></head>中加入以下代码。


注意事项:

javaScriptJavaScript基于对象和事件驱动并具有相对安全性的客户端脚本语言。也是一种广泛用于客户端Web开发的脚本语言,常用来给HTML网页添加动态功能,比如响应用户的各种操作。

‘伍’ js如何获取缓存

1、创建一个cache.js文件,前端页面,定义那些数据需要一次性拿到前端缓存,定义一个对象来保存这些数据。

‘陆’ js缓存怎样清理

浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能。但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据。像股票类网站实时更新等,这样的网站是不要缓存的,像有的网站很少更新,有缓存还是比较好的。今天主要介绍清除缓存的几种方法。
清理网站缓存的几种方法
meta方法
<METAHTTP-EQUIV="pragma"CONTENT="no-cache">
<METAHTTP-EQUIV="Cache-Control"CONTENT="no-cache,must-revalidate">
<METAHTTP-EQUIV="expires"CONTENT="0">123
清理form表单的临时缓存
方式一:用ajax请求服务器最新文件,并加上请求头If-Modified-Since和Cache-Control,如下:
$.ajax({
url:'www.haorooms.com',
dataType:'json',
data:{},
beforeSend:function(xmlHttp){
xmlHttp.setRequestHeader("If-Modified-Since","0");
xmlHttp.setRequestHeader("Cache-Control","no-cache");
},
success:function(response){
//操作
}
async:false
});12345678910111213
方法二,直接用cache:false,
$.ajax({
url:'www.haorooms.com',
dataType:'json',
data:{},
cache:false,
ifModified:true,

success:function(response){
//操作
}
async:false
});123456789101112
方法三:用随机数,随机数也是避免缓存的一种很不错的方法!
URL参数后加上"?ran="+Math.random();//当然这里参数ran可以任意取了
eg:
<script>
document.write("<s"+"cripttype='text/javascript'src='/js/test.js?"+Math.random()+"'></scr"+"ipt>");
</script>

其他的类似,只需在地址后加上+Math.random()
注意:因为Math.random()只能在Javascript下起作用,故只能通过Javascript的调用才可以12345678
方法四:用随机时间,和随机数一样。
在URL参数后加上"?timestamp="+newDate().getTime();1
用php后端清理
在服务端加header("Cache-Control:no-cache,must-revalidate");等等(如php中)1
方法五:
5、window.location.replace("WebForm1.aspx");
参数就是你要覆盖的页面,replace的原理就是用当前页面替换掉replace参数指定的页面。
这样可以防止用户点击back键。使用的是javascript脚本,举例如下:
a.html
以下是引用片段:
<html>
<head>
<title>a</title>
<scriptlanguage="javascript">
functionjump(){
window.location.replace("b.html");
}
</script>
</head>
<body>
<ahref="javascript:jump()">b</a>
</body>
</html>

b.html
以下是引用片段:
<html>
<head>
<title>b</title>
<scriptlanguage="javascript">
functionjump(){
window.location.replace("a.html");
}
</script>
</head>
<body>
<ahref="javascript:jump()">a</a>
</body>
</html>

‘柒’ JS如何清除IE浏览器缓存

一、CSS和JS为什么带参数(形如.css?t=与.js?t=)怎样获取代码
css和js带参数(形如.css?t=与.js?t=)
使用参数有两种可能:
第一、脚本并不存在,而是服务端动态生成的,因此带了个版本号,以示区别。 即上面代码对于文件来说 等价于 但浏览器会认为他是 该文件的某个版本!
第二、客户端会缓存这些css或js文件,因此每次升级了js或css文件后,改变版本号,客户端浏览器就会重新下载新的js或css文件 ,刷性缓存的作用。
第二种情况最多,也可能两种同时存在。
版本号,可以是一个随机数,也可以是一个递增的值,大版本小版本的方式,或者根据脚本的生成时间书写,比如就是精确到了生成脚本的秒,而 2.3.3 就是大版本小版本的方式。
二、关于浏览器缓存
浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能。但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据。像股票类网站实时更新等,这样的网站是不要缓存的,像有的网站很少更新,有缓存还是比较好的。今天主要介绍清除缓存的几种方法。
清理网站缓存的几种方法
meta方法
<META HTTP-EQUIV="pragma" CONTENT="no-cache"> <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate"> <META HTTP-EQUIV="expires" CONTENT="0">123

清理form表单的临时缓存
方式一:用ajax请求服务器最新文件,并加上请求头If-Modified-Since和Cache-Control,如下:
$.ajax({
url:'www.haorooms.com',
dataType:'json',
data:{},
beforeSend :function(xmlHttp){
xmlHttp.setRequestHeader("If-Modified-Since","0");
xmlHttp.setRequestHeader("Cache-Control","no-cache");
},
success:function(response){
//操作
}
async:false
});12345678910111213

方法二,直接用cache:false,
$.ajax({
url:'www.haorooms.com',
dataType:'json',
data:{},
cache:false,
ifModified :true ,

success:function(response){
//操作
}
async:false
});123456789101112

方法三:用随机数,随机数也是避免缓存的一种很不错的方法!
URL 参数后加上 "?ran=" + Math.random(); //当然这里参数 ran可以任意取了eg:
<script>
document.write("<s"+"cript type='text/javascript' src='/js/test.js?"+Math.random()+"'></scr"+"ipt>");
</script>

其他的类似,只需在地址后加上+Math.random()
注意:因为Math.random() 只能在Javascript 下起作用,故只能通过Javascript的调用才可以 12345678

方法四:用随机时间,和随机数一样。
在 URL 参数后加上 "?timestamp=" + new Date().getTime(); 1

用php后端清理
在服务端加 header("Cache-Control: no-cache, must-revalidate");等等(如php中)1

方法五:
5、window.location.replace("WebForm1.aspx");
参数就是你要覆盖的页面,replace的原理就是用当前页面替换掉replace参数指定的页面。
这样可以防止用户点击back键。使用的是javascript脚本,举例如下:
a.html
以下是引用片段:
<html>
<head>
<title>a</title>
<script language="javascript">
function jump(){
window.location.replace("b.html");
}
</script>
</head>
<body>
<a href="javascript:jump()">b</a>
</body> </html> b.html
以下是引用片段:
<html>
<head>
<title>b</title>
<script language="javascript">
function jump(){
window.location.replace("a.html");
}
</script>
</head>
<body>
<a href="javascript:jump()">a</a>
</body> </html>

转载地址:http://www.haorooms.com/post/js_llq_hc

‘捌’ 如何清除在浏览器 中的js缓存文件

关于浏览器缓存

浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能。但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据。像股票类网站实时更新等,这样的网站是不要缓存的,像有的网站很少更新,有缓存还是比较好的。今天主要介绍清除缓存的几种方法。

清理网站缓存的几种方法

meta方法

?

1
2
3
4

//不缓存
<META HTTP-EQUIV="pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">
<META HTTP-EQUIV="expires" CONTENT="0">

清理form表单的临时缓存

<body onLoad="javascript:document.yourFormName.reset()">

其实form表单的缓存对于我们书写还是有帮助的,一般情况不建议清理,但是有时候为了安全问题等,需要清理一下!

jquery ajax清除浏览器缓存

方式一:用ajax请求服务器最新文件,并加上请求头If-Modified-Since和Cache-Control,如下:

?

1
2
3
4
5
6
7
8
9
10
11
12
13

$.ajax({
url:'www.haorooms.com',
dataType:'json',
data:{},
beforeSend :function(xmlHttp){
xmlHttp.setRequestHeader("If-Modified-Since","0");
xmlHttp.setRequestHeader("Cache-Control","no-cache");
},
success:function(response){
//操作
}
async:false
});

方法二,直接用cache:false,

?

1
2
3
4
5
6
7
8
9
10
11

$.ajax({
url:'www.haorooms.com',
dataType:'json',
data:{},
cache:false,
ifModified :true ,
success:function(response){
//操作
}
async:false
});

方法三:用随机数,随机数也是避免缓存的一种很不错的方法!

URL 参数后加上 "?ran=" + Math.random(); //当然这里参数 ran可以任意取了

方法四:用随机时间,和随机数一样。

在 URL 参数后加上 "?timestamp=" + new Date().getTime();

用php后端清理

在服务端加 header("Cache-Control: no-cache, must-revalidate");等等(如php中)

方法五:

window.location.replace("WebForm1.aspx");

参数就是你要覆盖的页面,replace的原理就是用当前页面替换掉replace参数指定的页面。

这样可以防止用户点击back键。使用的是javascript脚本,举例如下:

a.html

以下是引用片段:

?

1
2
3
4
5
6
7
8
9
10
11
12
13

<html>
<head>
<title>a</title>
<script language="javascript">
function jump(){
window.location.replace("b.html");
}
</script>
</head>
<body>
<a href="javascript:jump()" rel="external nofollow" rel="external nofollow" >b</a>
</body>
</html>

b.html

以下是引用片段:

热点内容
数据库的酸性 发布:2025-05-16 11:03:17 浏览:123
phpmysql长连接 发布:2025-05-16 10:51:50 浏览:733
android横屏全屏 发布:2025-05-16 10:47:43 浏览:474
服务器直链下载搭建 发布:2025-05-16 10:47:38 浏览:174
编译不成功怎么办 发布:2025-05-16 10:35:54 浏览:612
如何修改密码找回 发布:2025-05-16 10:35:53 浏览:570
怎么才能编译本书 发布:2025-05-16 10:27:47 浏览:759
ssd服务器电脑 发布:2025-05-16 10:26:25 浏览:829
水果忍者源码 发布:2025-05-16 10:26:22 浏览:474
python中ord函数 发布:2025-05-16 10:14:25 浏览:341