Cookie与Session
Cookie和session是目前使用的两种存储机制。
cookie是从一个WEB页到下一个WEB页面的数据传送方法,cookie存储在客户端。
Session是让数据在页面中持续有效的一个传递方法,session存储在服务器端。
掌握了cookie与session这两个技术,在WEB网站页面间信息传递的安全性是非常必要的,也是必不可少的。
一、 Cookie管理
1、 Cookie
Cookie是一种在远程浏览器端存储数据并以此跟踪和识别用户的机制。简单的说,cookie是WEB服务器暂时存储在用户硬盘上的一个文本文件,并随后被WEB浏览器读取。当用户在次访问WEB网站时,网站通过读取cookie文件记录这位访客的特定信息(如上次访问的位置、花费的时间、用户名和密码等)从而迅速做出响应,如在页面中不需要输入用户名和密码等,就可以直接登录网站等。文本文件的命令格式如下:
用户名@网站地址[数字].txt
打开”我的电脑”—C盘(系统盘)---documentsand settings—administrator—cookie
这个路径就是cookie文件存储的路径。Administrator是当前使用的用户名,也就是登录本机的用户名,administrator@sogou[1].txt是指定格式自动生成的cookie文件,index.dat是用来保储所有打开的WEB网站的信息,该文件会随着用户打开的网站随时进行更新,在cookie文件夹下的每一个cookie文件都是一个简单而又普通的文本文件,而不是程序。Cookie中的内容大多是经过了加密处理的,因此表面看起来只是一些字母和数字的组合,这些内容只有服务器才知道他们真正的含义。
Cookie常用于以下3个方面:
记录访客的某些信息。如可以利用cookie记录用户访问网页的次数,或者记录访客曾经输入过的信息,另外,某些网站可以应用cookie自动记录访客上次登录的用户名。
在页面之间传递变量。浏览器并不会保存当前页面上任何变量信息的,当页面被关闭,页面上的任何变量信息将随之消失。如果用户声明一个变量id=8,要把这个变量传递到另一个页面,可以把变量id以cookie形式保存下来,然后在下一页通过读取该cookie来获取变量的值。
将所查看的internet页礁在cookie临时文件夹中,这样可以提高以后浏览的速度。
2、 创建Cookie
在PHP中通过setcookie函数创建Cookie。在创建之前必须了解的是,cookie是HTTP头标的组成部分,而头标必须在页面其他内容之前发送,它必须最先输出,即使在setcookie()函数前输出一个HTML标记或echo语句,甚至一个空行都会导致程序出错。语法如下:
Bool setcookie(string name[,string value[,int expire [,stringpath [,string domain [,int secure]]]]])
该函数的参数说明如表:
Name cookie的变量名 可以通过$_cookie[“cookiename”]调用变量名cookiename的cookie
Value cookie的变理名 该值保存在客户端不能用来保存敏感数据。可以通过$_cookie[“value”]获取名为values的值
Expire cookie的失效时间,expire是标准的UNIX时间标记,可以用time()函数或mktime()函数获取,单位为秒。
Path cookie在服务器端的有效路径 如果该参数设置为“/”,则它就在整个domain下的/11目录及子目录内有效。默认是当前目录。
Domain cookie有效的域名 如果要使cookie在mrbccd.com域名下的所有子域都有效,应该设置为mrbccd.com
Secure 指明cookie是否通过仅通过安全的https,值为0或1,如果值为1,则cookie只能在HTTPS连接上有效,如果值为默认值0,则cookie在HTTP和HTTPS连接上均有效。
例:
setcookie("TMCcookie","www.baidu.com");
setcookie("TMCcookie","www.baidu.com",time()+60); //设置cookie有效时间为60秒
setcookie("TMCcookie",$value,time()+3600,"/cs/","baidu.com",1);
?>
3、 读取Cookie
在PHP中可以直接通过超级全局数据$_cookie[]来读取浏览器端的cookie值。
例:
if(!isset($_COOKIE["visittime"])){ //检测cookie文件是否存在,如果不存在,往下执行
setcookie("visittime",date("y-m-d H:i:s")); //设置一个cookie变量
echo "欢迎第一次访问网站。";
}else{
setcookie("visittime",date("y-m-dH:i:s"),time()+60); //如果存在,设置上带cookie失效时间的变量。
echo "您上一次访问的时间为:".$_COOKIE["visittime"];
echo " ";
}
echo "您本次访问网站的时间为:".date("y-m-dH:i:s");
?>
过60秒后我们刷新,则显示的是第一次访问的时间。
如果未设置cookie的到期时间,则在关闭浏览器时自动删除cookie数据。如果为cookie设置了到期时间,浏览器将会记住cookie数据,即使用户重新启动计算机,只要没有到期,再访问网站时也会获得数据信息。
4、 删除Cookie
当cookie被创建后,如果没有设置它的失效时间,其cookie文件会在关闭浏览器时被自动删除。如果想在关闭浏览器之前删除cookie文件,方法有两种:一种是使用setcookie()函数删除,另一种是使用浏览器手动删除cookie。
(1)、使用setcookie()函数删除cookie
删除cookie和创建cookie的方式基本类似,删除cookie也使用setcookie()函数。删除cookie只需要将setcookie()函数中第二个参数设置为空值,将第三个参数cookie的过期时间设置为小于系统的当前时间即可。
例如:将cookie的过期时间设置为当前时间减1秒,代码如下:
setcookie("name","",time()-1);
time()函数返回以秒表示的当前时间戳,把过期时间减1秒就会得到过去的时间,从而删除cookie. 注意:把过期时间设置为0,可以直接删除cookie.
(2)、使用浏览器手动删除cookie
在使用cookie时,cookie自动生成一个文本文件存储在IE浏览器的cookies临时文件夹中。使用浏览器删除cookie文件是非常便捷的方法。
打开一个页面-----工具-----internet选项,在“常规”选项卡------删除cookie按钮,弹出“删除temporaryinternet files文件夹中的所有cookies吗?”-----单击“确定”,即可成功删除全部cookie文件。
5、 Cookie的生命周期
如果cookie不设定时间,就表示它的生命周期为浏览器会话的期间,只要关闭IE浏览器,cookie就会自动消失。这种cookie被称为会话cookie,一般不保存在硬盘上,而是保存在内存中。
如果设置了过期时间,那么浏览器会把cookie保存到硬盘中,再次打开IE浏览器时会被依然有效,直到它的有效期超时。
虽然cookie可以长期保存在客户端浏览器中,但也不是一成不变的。因为浏览器允许最多存储300个cookie文件,而且每个cookie文件支持最大容量为4KB,每个域名最多支持20个cookie,如果达到限制,浏览器会自动地随机删除cookies.
6、 Cookie的综合应用
在进行网站开发时,都需要制作一个计数器来记录网站的访问量,以此来吸引更多的访客关注网站。
例:
if(!empty($_COOKIE["counter"])){
$counter=$_COOKIE["counter"]+1;
}
else{
$counter=1;
}
setcookie("counter",$counter,time()+2678400);
echo "您是第".$counter."位访客。";
?>
关闭浏览器时也不会停止记数,除非C:\Documents and Settings\Administrator\LocalSettings\Temporary Internet Files将文件进行删除才可以。
计数器的实现方法有多种。
二、 Session管理
对比cookie,会话文件中保存的数据是在PHP脚本中以变量的形式创建的,创建的会话变量在生命周期(20分钟)中可以被跨页的请求所引用。另外,session是存储在服务器端的会话,相对安全,并且不像cookie那样有存储长度的限制。
1、 了解session
Session被译成中文为“会话”,其本义是指有始有终的一系列动作/消息,如打电话。
在计算机专业术语中,session是指一个终端用户与交互系统进行通信的时间间隔,通常指从注册进入系统到注销退出系统之间所经过的时间。因此,session实现上是一个特定的时间概念。
2、 Session的功能
Session在WEB技术中占有非常重要的份量。由于网页是一种无状态的连接程序。因此无法得知用户的浏览状态。因此必须通过session记录用户的有关信息,以供用户再次以此身份对WEB服务器提供要求时作确认。例,在电子商务网站中,通过session记录用户登录的信息,以及用户所购买的商品,如果没有session,那么用户就会每进入一个页面都登录一遍用户名和密码。
另外,session会话适用于存储用户的信息量比较小的情况。如果用户需要存储的信息量相对较少,并用对存储内容不需要长期存储,那么使用session把信息存储到服务器端比较适合。
3、 创建会话
创建一个会话需要通过以下几个步骤实现:
启动会话--------注册会话-------使用会话-------删除会话
1) 启动会话
启动会话的方式有两种:一种是使用session_start()函数,另一种使用session_register()函数为会话登录一个变量来隐含地启动会话。
通常,session_start()函数在页面开始位置调用,然后会话变量被登录到数据$_session。
其语法格式为:
Bool session_start(void);
使用session_start()函数之前浏览器不能有任何输出,否则会产生类似以下的错误提示。
如果想使用session_satrt()这个全局变量来存储你的数据的话得在php.ini文件中配置你的信息:
session.save_path = "D:/program files/php/temp"
例:
echo "呵呵……";
session_start();
?>
运行结果如下:
呵呵……
Warning : session_start()[ function.session-start]:Cannot send session cache limiter - headers already sent (output started atC:\webserver\wwwroot\11.php:1) in
C:\webserver\wwwroot\11.php on line
3
session_start();
?>
注意:该代码前不要有任何的代码,如果新建的文件默认有的内容,要删除。
Session_register()函数用来为会话登录一个变量来隐含地启动会话,但要求设置php.ini文件的选项,将register_globals指令设置为ON,然后重新启动apache服务器。
使用session_register()函数时,不需要调用session_start()函数,PHP会在注册变量之后隐含地调用session_start()函数。
2) 注册会话
会话变量被启动后,全部保存在数组$_session中。通过数组$_session创建一个会话变量很容易,只要直接给该数组添加一个元素即可。
例:
session_start();
$_SESSION["admin"]=null;
?>
3) 使用会话
首先需要判断会话变量是否有一个会话ID存在,如果不存在,就创建一个,并且使用其能够通过全局数组$_SESSION进行访问。如果已经存在,则将这个已注册的会话变量载入以供用户使用。
例:
session_start();
$_SESSION["admin"]=id;
if(!empty($_SESSION["admin"])){
$myvalue=$_SESSION["admin"];
echo $myvalue;
}else{
echo "该会话不存在。";
}
?>
4) 删除会话
删除会话的方法主要有删除单个会话、删除多个会话和结束当前会话的3种。
a) 删除单个会话
删除会话变量,同数组的操作一样,直接注销$_SESSION数组的某个元素即可。
例如:注销$_SESSION[“admin”]变量,可以使用unset()函数,代码如下:
unset($_SESSION["admin"]);
b) 删除多个会话
如果想要一次注销所有的会话变量,可以将一个空的数组赋值给$_SESSION,代码如下:
$_SESSION=array();
c) 结束当前的会话
如果整个会话已经结束,首先应该注销所有的会话变量,然后使用session_destroy()函数清除结束当前的会话,并清空会话中的所有资源,彻底销毁session,代码如下:
session_destroy();
4、 Session的综合应用----通过session判断用户的操作权限
大多数网站的开发过程中,需要对管理员和普通用户对操作网站的权限进行划分。
例:13.php
用session判断用户操作权限
用户名:
密 码:
check_13.php
session_start();
$_SESSION[user]=$_POST[user];
$_SESSION[pwd]=$_POST[pwd];
?>
check_13.php
if($_SESSION[user]==""){
echo"";
}
if($_SESSION[user]=="123" &&$_SESSION[pwd]=="123"){
echo "您是管理员用户 ";
}else{
echo "您是普通用户";
}
?>
session_start();
unset($_SESSION[user]);
unset($_SESSION[pwd]);
session_destroy();
?>
三、 Cookie与Session的比较
它们最大的区别是Session是将Session的信息保存在服务器上,并通过一个Sessionid来传递客户的信息,同时服务器接收到Sessionid后,根据这个ID来提供相关的Session资源;cookie是将所有的信息以文本文件的形式保存在客户端,并由浏览器进行管理和维护。
由于session为服务器存储,所以远程用户无法修改session文件的内容。而cookie为客户端存储,所以session要比cookie安全得多。当然使用session还有很多优点,如控制容易,可以按照用户自定义存储(存储于数据库)。
你可能感兴趣的:(session_cookie)
.net session_cookie简介
诺亚蜗牛_Snail
cookiecookie是什么?存储在客户端浏览器(客户端硬盘)中的一段数据。cookie的作用?保存用户的状态信息。(会话跟踪)cookie的主要作用就是用来保存状态的。因为http协议是无状态的,所以要想保存用户的状态信息,必须自己来实现,可以通过cookie来实现。cookie的特点:1.保存的数据量大小有限制。2.cookie可以设置有效期。当把有效期设置为已经过期的日期,那么浏览器就会删
haproxy负载均衡保持客户端和服务器Session亲缘性的三种方式:
kexl
haproxy cookie balance
1用户IP识别haroxy将用户IP经过hash计算后指定到固定的真实服务器上(类似于nginx的IPhash指令)配置指令 balancesource2cookie识别 haproxy将WEB服务端发送给客户端的cookie中插入(或添加加前缀)haproxy定义的后端的服务器COOKIEID。配置指令例举 cookie SESSION_COOKIE insertindirectnocac
jvm调优总结(从基本概念 到 深度优化)
oloz
java jvm jdk 虚拟机 应用服务器
JVM参数详解:http://www.cnblogs.com/redcreen/archive/2011/05/04/2037057.html
Java虚拟机中,数据类型可以分为两类:基本类型和引用类型。基本类型的变量保存原始值,即:他代表的值就是数值本身;而引用类型的变量保存引用值。“引用值”代表了某个对象的引用,而不是对象本身,对象本身存放在这个引用值所表示的地址的位置。
【Scala十六】Scala核心十:柯里化函数
bit1129
scala
本篇文章重点说明什么是函数柯里化,这个语法现象的背后动机是什么,有什么样的应用场景,以及与部分应用函数(Partial Applied Function)之间的联系 1. 什么是柯里化函数
A way to write functions with multiple parameter lists. For instance
def f(x: Int)(y: Int) is a
HashMap
dalan_123
java
HashMap在java中对很多人来说都是熟的;基于hash表的map接口的非同步实现。允许使用null和null键;同时不能保证元素的顺序;也就是从来都不保证其中的元素的顺序恒久不变。
1、数据结构
在java中,最基本的数据结构无外乎:数组 和 引用(指针),所有的数据结构都可以用这两个来构造,HashMap也不例外,归根到底HashMap就是一个链表散列的数据
Java Swing如何实时刷新JTextArea,以显示刚才加append的内容
周凡杨
java 更新 swing JTextArea
在代码中执行完textArea.append("message")后,如果你想让这个更新立刻显示在界面上而不是等swing的主线程返回后刷新,我们一般会在该语句后调用textArea.invalidate()和textArea.repaint()。
问题是这个方法并不能有任何效果,textArea的内容没有任何变化,这或许是swing的一个bug,有一个笨拙的办法可以实现
servlet或struts的Action处理ajax请求
g21121
servlet
其实处理ajax的请求非常简单,直接看代码就行了:
//如果用的是struts
//HttpServletResponse response = ServletActionContext.getResponse();
// 设置输出为文字流
response.setContentType("text/plain");
// 设置字符集
res
FineReport的公式编辑框的语法简介
老A不折腾
finereport 公式 总结
FINEREPORT用到公式的地方非常多,单元格(以=开头的便被解析为公式),条件显示,数据字典,报表填报属性值定义,图表标题,轴定义,页眉页脚,甚至单元格的其他属性中的鼠标悬浮提示内容都可以写公式。
简单的说下自己感觉的公式要注意的几个地方:
1.if语句语法刚接触感觉比较奇怪,if(条件式子,值1,值2),if可以嵌套,if(条件式子1,值1,if(条件式子2,值2,值3)
linux mysql 数据库乱码的解决办法
墙头上一根草
linux mysql 数据库乱码
linux 上mysql数据库区分大小写的配置
lower_case_table_names=1 1-不区分大小写 0-区分大小写
修改/etc/my.cnf 具体的修改内容如下:
[client]
default-character-set=utf8
[mysqld]
datadir=/var/lib/mysql
socket=/va
我的spring学习笔记6-ApplicationContext实例化的参数兼容思想
aijuans
Spring 3
ApplicationContext能读取多个Bean定义文件,方法是:
ApplicationContext appContext = new ClassPathXmlApplicationContext(
new String[]{“bean-config1.xml”,“bean-config2.xml”,“bean-config3.xml”,“bean-config4.xml
mysql 基准测试之sysbench
annan211
基准测试 mysql基准测试 MySQL测试 sysbench
1 执行如下命令,安装sysbench-0.5:
tar xzvf sysbench-0.5.tar.gz
cd sysbench-0.5
chmod +x autogen.sh
./autogen.sh
./configure --with-mysql --with-mysql-includes=/usr/local/mysql
sql的复杂查询使用案列与技巧
百合不是茶
oracle sql 函数 数据分页 合并查询
本片博客使用的数据库表是oracle中的scott用户表;
------------------- 自然连接查询
查询 smith 的上司(两种方法)
&
深入学习Thread类
bijian1013
java thread 多线程 java多线程
一. 线程的名字
下面来看一下Thread类的name属性,它的类型是String。它其实就是线程的名字。在Thread类中,有String getName()和void setName(String)两个方法用来设置和获取这个属性的值。
同时,Thr
JSON串转换成Map以及如何转换到对应的数据类型
bijian1013
java fastjson net.sf.json
在实际开发中,难免会碰到JSON串转换成Map的情况,下面来看看这方面的实例。另外,由于fastjson只支持JDK1.5及以上版本,因此在JDK1.4的项目中可以采用net.sf.json来处理。
一.fastjson实例
JsonUtil.java
package com.study;
impor
【RPC框架HttpInvoker一】HttpInvoker:Spring自带RPC框架
bit1129
spring
HttpInvoker是Spring原生的RPC调用框架,HttpInvoker同Burlap和Hessian一样,提供了一致的服务Exporter以及客户端的服务代理工厂Bean,这篇文章主要是复制粘贴了Hessian与Spring集成一文,【RPC框架Hessian四】Hessian与Spring集成
在
【RPC框架Hessian二】Hessian 对象序列化和反序列化一文中
【Mahout二】基于Mahout CBayes算法的20newsgroup的脚本分析
bit1129
Mahout
#!/bin/bash
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information re
nginx三种获取用户真实ip的方法
ronin47
随着nginx的迅速崛起,越来越多公司将apache更换成nginx. 同时也越来越多人使用nginx作为负载均衡, 并且代理前面可能还加上了CDN加速,但是随之也遇到一个问题:nginx如何获取用户的真实IP地址,如果后端是apache,请跳转到<apache获取用户真实IP地址>,如果是后端真实服务器是nginx,那么继续往下看。
实例环境: 用户IP 120.22.11.11
java-判断二叉树是不是平衡
bylijinnan
java
参考了
http://zhedahht.blog.163.com/blog/static/25411174201142733927831/
但是用java来实现有一个问题。
由于Java无法像C那样“传递参数的地址,函数返回时能得到参数的值”,唯有新建一个辅助类:AuxClass
import ljn.help.*;
public class BalancedBTree {
BeanUtils.copyProperties VS PropertyUtils.copyProperties
诸葛不亮
PropertyUtils BeanUtils
BeanUtils.copyProperties VS PropertyUtils.copyProperties
作为两个bean属性copy的工具类,他们被广泛使用,同时也很容易误用,给人造成困然;比如:昨天发现同事在使用BeanUtils.copyProperties copy有integer类型属性的bean时,没有考虑到会将null转换为0,而后面的业
[金融与信息安全]最简单的数据结构最安全
comsci
数据结构
现在最流行的数据库的数据存储文件都具有复杂的文件头格式,用操作系统的记事本软件是无法正常浏览的,这样的情况会有什么问题呢?
从信息安全的角度来看,如果我们数据库系统仅仅把这种格式的数据文件做异地备份,如果相同版本的所有数据库管理系统都同时被攻击,那么
vi区段删除
Cwind
linux vi 区段删除
区段删除是编辑和分析一些冗长的配置文件或日志文件时比较常用的操作。简记下vi区段删除要点备忘。
vi概述
引文中并未将末行模式单独列为一种模式。单不单列并不重要,能区分命令模式与末行模式即可。
vi区段删除步骤:
1. 在末行模式下使用:set nu显示行号
非必须,随光标移动vi右下角也会显示行号,能够正确找到并记录删除开始行
清除tomcat缓存的方法总结
dashuaifu
tomcat 缓存
用tomcat容器,大家可能会发现这样的问题,修改jsp文件后,但用IE打开 依然是以前的Jsp的页面。
出现这种现象的原因主要是tomcat缓存的原因。
解决办法如下:
在jsp文件头加上
<meta http-equiv="Expires" content="0"> <meta http-equiv="kiben&qu
不要盲目的在项目中使用LESS CSS
dcj3sjt126com
Web less
如果你还不知道LESS CSS是什么东西,可以看一下这篇文章,是我一朋友写给新人看的《CSS——LESS》
不可否认,LESS CSS是个强大的工具,它弥补了css没有变量、无法运算等一些“先天缺陷”,但它似乎给我一种错觉,就是为了功能而实现功能。
比如它的引用功能
?
.rounded_corners{
[入门]更上一层楼
dcj3sjt126com
PHP yii2
更上一层楼
通篇阅读完整个“入门”部分,你就完成了一个完整 Yii 应用的创建。在此过程中你学到了如何实现一些常用功能,例如通过 HTML 表单从用户那获取数据,从数据库中获取数据并以分页形式显示。你还学到了如何通过 Gii 去自动生成代码。使用 Gii 生成代码把 Web 开发中多数繁杂的过程转化为仅仅填写几个表单就行。
本章将介绍一些有助于更好使用 Yii 的资源:
Apache HttpClient使用详解
eksliang
httpclient http协议
Http协议的重要性相信不用我多说了,HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们再讨论),它不仅是客户端发送Http请求变得容易,而且也方便了开发人员测试接口(基于Http协议的),即提高了开发的效率,也方便提高代码的健壮性。因此熟练掌握HttpClient是很重要的必修内容,掌握HttpClient后,相信对于Http协议的了解会
zxing二维码扫描功能
gundumw100
android zxing
经常要用到二维码扫描功能
现给出示例代码
import com.google.zxing.WriterException;
import com.zxing.activity.CaptureActivity;
import com.zxing.encoding.EncodingHandler;
import android.app.Activity;
import an
纯HTML+CSS带说明的黄色导航菜单
ini
html Web html5 css hovertree
HoverTree带说明的CSS菜单:纯HTML+CSS结构链接带说明的黄色导航
在线体验效果:http://hovertree.com/texiao/css/1.htm代码如下,保存到HTML文件可以看到效果:
<!DOCTYPE html >
<html >
<head>
<title>HoverTree
fastjson初始化对性能的影响
kane_xie
fastjson 序列化
之前在项目中序列化是用thrift,性能一般,而且需要用编译器生成新的类,在序列化和反序列化的时候感觉很繁琐,因此想转到json阵营。对比了jackson,gson等框架之后,决定用fastjson,为什么呢,因为看名字感觉很快。。。
网上的说法:
fastjson 是一个性能很好的 Java 语言实现的 JSON 解析器和生成器,来自阿里巴巴的工程师开发。
基于Mybatis封装的增删改查实现通用自动化sql
mengqingyu
DAO
1.基于map或javaBean的增删改查可实现不写dao接口和实现类以及xml,有效的提高开发速度。
2.支持自定义注解包括主键生成、列重复验证、列名、表名等
3.支持批量插入、批量更新、批量删除
<bean id="dynamicSqlSessionTemplate" class="com.mqy.mybatis.support.Dynamic
js控制input输入框的方法封装(数字,中文,字母,浮点数等)
qifeifei
javascript js
在项目开发的时候,经常有一些输入框,控制输入的格式,而不是等输入好了再去检查格式,格式错了就报错,体验不好。 /** 数字,中文,字母,浮点数(+/-/.) 类型输入限制,只要在input标签上加上 jInput="number,chinese,alphabet,floating" 备注:floating属性只能单独用*/
funct
java 计时器应用
tangqi609567707
java timer
mport java.util.TimerTask; import java.util.Calendar; public class MyTask extends TimerTask { private static final int
erlang输出调用栈信息
wudixiaotie
erlang
在erlang otp的开发中,如果调用第三方的应用,会有有些错误会不打印栈信息,因为有可能第三方应用会catch然后输出自己的错误信息,所以对排查bug有很大的阻碍,这样就要求我们自己打印调用的栈信息。用这个函数:erlang:process_display (self (), backtrace).需要注意这个函数只会输出到标准错误输出。
也可以用这个函数:erlang:get_s