草庐IT

transaction_safe

全部标签

Javascript 清理 : The most safe way to insert possible XSS html string

目前我正在将此方法与jQuery解决方案结合使用,以从可能的XSS攻击中清除字符串。sanitize:function(str){//returnhtmlentities(str,'ENT_QUOTES');return$('').text(str).html().replace(/"/gi,'"').replace(/'/gi,''');}但我觉得它不够安全。我错过了什么吗?我在这里尝试了phpjs项目中的htmlentities:http://phpjs.org/functions/htmlentities:425/但它有点错误并返回一些额外的特殊符号。也许是旧

带有嵌入式 Ruby : How to safely assign a ruby value to a javascript variable 的 Javascript

我在页面的javascriptblock中有这一行:res=foo('');处理@ruby_var中有单引号的情况的最佳方法是什么?否则它会破坏JavaScript代码。 最佳答案 我想我会使用rubyJSON@ruby_var上的库,为字符串获取正确的js语法并去掉'',fex.:res=foo()(在require"json"'ing之后,不完全确定如何在页面中执行此操作,或者上述语法是否正确,因为我没有使用该模板语言)(另一方面,如果JSON曾经更改为与js不兼容,那将会中断,但由于大量代码使用eval()来评估json,我怀

javascript - 在没有 transaction.get() 的情况下启动 firestore 事务

我想将文档从一个集合移动到另一个集合。因此,我想使用事务来1.创建新文档和2.删除旧文档。我可以执行以下操作:db.runTransaction((transaction)=>{returntransaction.get(docRef).then(()=>transaction.set(newDocRef.doc(docId),doc)).then(()=>transaction.delete(docRef));我如何重写此代码以从transaction.set()而不是transaction.get()开始,因为我已经有了这个上下文中的文档,所以它是多余的。区别在于transacti

javascript - 未捕获的 InvalidStateError : Failed to execute 'transaction' on 'IDBDatabase' : A version change transaction is running

我必须承认我是indexedDB的新手我写了一段indexedDB的简单代码,如下:functiongo(){varreq=window.indexedDB.open("Uploader",1),db;req.onerror=function(e){console.log("Error");};req.onsuccess=function(e){db=e.target.result;};req.onupgradeneeded=function(e){console.log(db);db=e.target.result;varos=db.createObjectStore("Files"

javascript - 如何让外部代码 'safe' 运行?只是禁止 eval()?

我希望能够让社区成员提供他们自己的javascript代码供其他人使用,因为用户的想象力集体远远超过我所能想到的。但这引发了固有的安全问题,特别是当目的是允许外部代码运行时。那么,我可以禁止提交中的eval()并结束它吗?还是有其他方法可以评估代码或在javascript中引起大规模panic?还有其他一些事情是不允许的,但我主要担心的是,除非我可以阻止字符串被执行,否则我为特定方法设置的任何其他过滤器都可以被绕过。可行,还是必须求助于作者提供网络服务接口(interface)? 最佳答案 自HTML5现在可以使用了sandbox对

javascript - 一个 "safe place"来评估 Javascript 中的受信任代码(具有特定上下文)? [编辑: how can you break it?]

不要在标题上评判我,我知道eval是邪恶的,但我这样做是有原因的,而且会非常有限。事情是这样的:我想创建一个安全的空间,我可以在其中运行特定的(和受信任的)代码,并检索结果(如果它符合我的期望)。出于安全原因,我想将它从所有其他范围中删除(这个空间被要求提供结果,并且应该不能单独将任何内容导出到周围的范围)。我找到了一个似乎可行的解决方案,它也可以为执行添加上下文,但我不确定它是否有效,或者该系统中是否存在安全漏洞。你能告诉我它是否有问题吗?它实际上创建了与全局变量同名的本地变量,以防止访问它们。它还剥离了功能(我将添加功能以保留我想要保留的功能)。该函数声明为最接近全局变量,以避免更

go - "safely escaped with Go syntax"是什么意思?

Go的fmt包将%q(对于字符串)定义为:%qadouble-quotedstringsafelyescapedwithGosyntaxWhatdoessafelyescapedwithGosyntaxmean?Someexperimentationshowsitpreservesescapesequencesusedintheoriginalstring:s:="Thishas\"quotes\"init"fmt.Printf("%q\n",s)//output:"Thishas\"quotes\"init"它还有什么作用吗?在什么情况下你可能想使用它?我猜也许在生成Go代码的模板中

go - 我可以在 GO 中使用 transaction.Stmt(sqlstatement).Exec(parameter) 时记录最终查询吗?

您好,我正在使用database/sql包,例如我有这个:varDeletePermissionStmt*sql.StmtDeletePermissionStmt,err=database.Prepare(`DELETEFROMpermissionWHEREpermission_id=$1`)iferr!=nil{log.Errorf("can'tpreparedeletepermissionstatement:%s",err.Error())}transaction,err:=database.Begin()//assumepostgresdatabaseisdefinedprevi

postgresql - Golang、postgres事务: pq: unexpected transaction status in a failed transaction

Go:v1.3db:postgres使用lib/pq我有一个更新postgres数据库的应用程序。postgres数据库是使用pgbouncer设置的。因此,通过事件连接,我有运行插入和更新的代码。这是插入代码:func(sitemap*SiteMapData)InsertSiteMap(dbConnection*sql.DB)(int64,error){tx,err:=dbConnection.Begin()iferr!=nil{l4g.Error("InsertSiteMap:couldnotbeingtransaction:%v",err)return0,err}result,e

具有不同超时的 Golang goroutine-safe http 客户端?

假设我有以下功能:funcSendRequest(c*Client,timeouttime.Duration){iftimeout>0{c.Timeout=timeout}else{c.Timeout=defaultTimeout}...}我想允许多个go-routines调用这个函数(共享同一个HTTP客户端),但是这样写显然不能保证goroutine的安全。(同时更改传入的客户端超时也很奇怪......)我不确定执行此操作的最佳方法是什么。我应该为不同的超时使用不同的客户端吗?我应该使用一些互斥量吗?或者一般来说,我如何共享具有不同超时的HTTP客户端?谢谢!