我正在构建一个说明常见应用漏洞(如sql注入)的站点.我使用AngularJS和highlight.js来创建交互式的例子.

如何使AngularJS和highlight.js更新我的代码片段?

This Fiddle演示如果用户的输入未被验证或消毒,在电子邮件字段中如何输入“OR 1 = 1”可能会更改查询的预期行为.

SELECT * FROM dbo.Users WHERE Email='{{email}}' AND Password='{{password}}'

当用户输入电子邮件地址和密码时,Angular会更新查询.但是,语法突出显示不会更新.

SELECT * FROM dbo.Users WHERE Email='user@domain.com' AND Password=''

我尝试重新初始化hljs,但是当我做角停止更新查询.

hljs.initHighlighting.called = false;
hljs.initHighlighting();

应用

<script>
    var app = angular.module("app",['hljs']);
    app.controller("controller",function($scope) {
        $scope.email = "user@domain.com";
        $scope.password = "";
    })
</script>
<div ng-app="app" ng-controller="controller">
    <div>
        <div class="row">
            <div class="col-sm-4">Email
                <input type="text" class="form-control" ng-model="email">
            </div>
            <div class="col-sm-4">Password
                <input type="text" class="form-control" ng-model="password">
            </div>
        </div>
        <br>
        <div hljs include="'compile-me'" compile="true" language="sql"></div>
    </div>
    <script type="text/ng-template" id="compile-me">
        SELECT * FROM dbo.Users WHERE Email = '{{email}}'
        AND Password = '{{password}}'
    </script>
</div>

解决方法

在jsfiddle你提供你使用 angular-highlightjs这在你的情况基本上:

>获取您提供的模板,include指令适用
>在生成HTML标记的模板上调用highlightjs库API,其中突出显示的元素具有特定语言的正确样式
>然后将突出显示的HTML标记传递给angularjs $compile

之后不会发生高光,尤其是当内插的内容发生变化时.

解决它的一个方法是使用来自angular-highlightjs的源指令,这是被观察到的,但我认为构建自定义指令更简单.

这里的诀窍是手动内插和突出显示内容.我已经更新了您的fiddle与一个简单的高亮指令,提出了想法:

app.directive('highlight',function($interpolate,$window){
    return {
    restrict: 'EA',scope: true,compile: function (tElem,tAttrs) {
      var interpolateFn = $interpolate(tElem.html(),true);
      tElem.html(''); // stop automatic intepolation

      return function(scope,elem,attrs){
        scope.$watch(interpolateFn,function (value) {
          elem.html(hljs.highlight('sql',value).value);
        });
      }
    }
  };
});

javascript – 使用AngularJS和Highlight.js进行动态语法突出显示的更多相关文章

  1. swift TabBar

    先上效果图如下:1.在APP的AppDelegate页面中加载TFTabBarViewController类2.创建FirstViewController,SecondViewController,ThirdViewController,FourthViewController四个页面,然后设置下页面的颜色(便于点击下面的TabBar时,可以看到切换的效果)3.将刚刚创建的页面加载到TabBar中

  2. 禁用Android中链接周围的橙色突出显示

    我已经尝试了一百万次去除Androidwebview上链接周围恼人的橙色高亮框,但它们似乎并没有消失.不,这不起作用:我真的很困惑,其他任何想法?我在galaxyS3上测试.解决方法尝试从here.结果真正棘手的是第二个属性,用户修改.我认为这是自4.0.4以来的要求,这恰好影响了galaxyS3等.您可以缩小选择器的范围,但必须影响链接的父级,例如或者,而不是链接本身.

  3. SyntaxHighlighter与ajax公用的时候不能正常显示代码高亮的解决方法

    SyntaxHighlighter是当前比较流行的一个高亮显示代码的插件,但今天在与ajax使用的时候遇到了无法正常高亮显示的问题,参考了http://stackoverflow.com/questions/6471526/use-Syntax-Highlighter-on-ajax-loaded-content的解决方法,把SyntaxHighlighter.all()换成SyntaxHighl

  4. angularjs – 未知提供程序从Angular 1.0切换到1.2.3

    在AngularJS1.2.1中,路径模块已在单个文件angular-route.min.js中拉出,您需要根据发布的错误添加对此文件的引用和angular-sanitize.min.js.您还需要在应用程序中注入ngRoute和ngSanitize:

  5. angularJs的国家选择控制

    p=preview使用ng-option指令使用ng-repeat指令:控制器中的国家范围:

  6. AngularJS在自定义指令中包含ui-select

    我设法通过在模板中设置ng-model来进行绑定工作

  7. angularjs – 更新数组时如何避免刷新ng-repeat DOM列表

    因此,“trackby”实际上将检查传入对象的属性并替换旧对象并仍然保留id.这很激烈.值得注意的是,“trackby”也适用于除ng-repeat之外的其他指令,例如select.我做了一个小小的演示,对于那些可能会对一切如何运作感到困惑的人……

  8. angularjs – 在测试angular指令时,isolateScope()返回undefined

    使用Angularv1.2.25和rails资产管道,我试图测试指令的隔离范围确实已经更新.由于isolateScope()返回undefined我得到预期未定义的定义…

  9. angularjs – 解释ngModel管道,解析器,格式化程序,viewChangeListeners和$watchers的顺序

    换句话说:如果在模型更新之前触发了“ng-change”,我可以理解,但是我很难理解在更新模型之后以及在完成填充更改之前触发函数绑定属性.如果您读到这里:祝贺并感谢您的耐心等待!

  10. angularjs – 如何使用jasmine测试$timeout操作的持续时间?

    假设我在指令中有以下匿名功能:这成功了.现在,如果我想编写一个测试,使用jasmine,以确保在~2s后删除该类,将如何做?我应该补充一点,到目前为止我尝试过使用jasmine.Clock和waitsFor方法,在这两种情况下,测试都失败了.值得注意的是,当我在指令中将$timeout更改为setTimeout时,两个测试都已通过,因此angular的行为似乎在这里发挥作用..从1.2$timeout.flush()开始,需要一个延迟参数来模拟类似于jasmine.Clock模拟的时钟,但是以一种使Ang

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部