我正在为半受信任的客户端编写一个简单的应用程序,对某些细节没有发言权。必须为客户端提供一份二进制文件 myTestApp,它使用外部库 libsecrets 中的专有代码。它是一个 Windows 应用程序,可以在几台独立的 Windows 7 笔记本电脑上运行。我被告知,在应用程序完成其目的后,它将被删除。我知道对此没有完美的解决方案,但我想在程序中实现一个到期日期,并阻止可能对代码进行逆向工程的努力,或者至少防止 libsecrets 的内容被泄露太容易暴露了。
所以,我的第一步是将
其次,我想实现某种不天真的 第三,如果没有“安全的” 接下来,有没有什么方法可以改变二进制文件,使个人无法通过查看汇编代码来尝试对其进行逆向工程?也许是某种加密二进制文件并需要第三方身份验证工具的包装器?或者我创建的某种证书需要运行它并稍后过期? 最后,是否有任何软件(即:打包或发布软件)可以通过重新打包最终的 myTestApp 静态链接到 libsecrets,这样所有内容都包含在一个二进制文件中,所以只有 libsecrets 包含在最终的二进制文件中,其接口(interface)不再发布。 或作为 Microsoft Visual Studio 的某种插件来为我做这件事?getTime 机制。 Windows 中是否有任何执行“安全”getTime 调用的东西,因此它不会被更改系统托盘或 BIOS 中的时间所欺骗?getTime 调用,我还可以修改 myTestApp 以使用 NTP 查询受信任的时间服务器,如果不能则失败'从中获取时间或试用期已过。但这可能会被网关上的 DNS 弄乱,除非有某种证书机制来验证时间服务器。不过我对此知之甚少,需要一些关于如何实现它的建议。
提前谢谢大家。
编辑:这并不是一个防弹系统,如果它失败了,那是可以接受的。我只是想让非技术人员不方便尝试破解。使用它的人是技术勒德分子,破解软件的唯一方法是他们雇人来做。由于名称和公司名称在应用程序中带有水印,并且只有一个人可以从其使用中受益,因此他们不太可能重新分发它。
最佳答案
你不能让事情完全安全,但你可以让它变得更难。
包装 UPX给黑客增加了一定程度的复杂性。
您可以在运行时检查您是在多个地方的调试器下运行还是在虚拟机下运行。
您可以加密您正在使用的 DLL 并手动加载它(复杂)。
您可以编写一个加载程序来检查您的应用程序的哈希值,您的应用程序可以检查加载程序的哈希值。
您可以获取系统时间并将其与您已经写入磁盘的系统时间进行比较,看看它是单调的。 一切都取决于您想要的保护级别。
如果您访问 PirateBay 或任何其他 Torrent 网站,您会发现如果黑客感兴趣,一切都会被黑客入侵。
关于c++ - 试用期满后禁用申请,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20688977/
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server
华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o
如何将send与+=一起使用?a=20;a.send"+=",10undefinedmethod`+='for20:Fixnuma=20;a+=10=>30 最佳答案 恐怕你不能。+=不是方法,而是语法糖。参见http://www.ruby-doc.org/docs/ProgrammingRuby/html/tut_expressions.html它说Incommonwithmanyotherlanguages,Rubyhasasyntacticshortcut:a=a+2maybewrittenasa+=2.你能做的最好的事情是:
作为新的阿里云用户,您可以50免费试用多种优惠,价值高达1,700美元(或8,500美元)。这将让您了解和体验阿里云平台上提供的一系列产品和服务。如果您以个人身份注册免费试用,您将获得价值1,700美元的优惠。但是,如果您是注册公司,您可以选择企业免费试用,提交基本信息通过企业实名注册验证,即可开始价值$8,500的免费试用!本教程介绍了如何设置您的帐户并使用您的免费试用版。关于免费试用在我们开始此试用之前,您还必须遵守以下条款和条件才能访问您的免费试用:只有在一年内创建的账户才有资格获得阿里云免费试用。通过此免费试用优惠,用户可以免费试用免费试用活动页面上列出的每种产品一次。如果您有多个帐
是否可以在PyYAML或Ruby的Psych引擎中禁用创建anchor和引用(并有效地显式列出冗余数据)?也许我在网上搜索时遗漏了一些东西,但在Psych中似乎没有太多可用的选项,而且我也无法确定PyYAML是否允许这样做.基本原理是我必须序列化一些数据并将其以可读的形式传递给一个不是真正的技术同事进行手动验证。有些数据是多余的,但我需要以最明确的方式列出它们以提高可读性(anchor和引用是提高效率的好概念,但不是人类可读性)。Ruby和Python是我选择的工具,但如果有其他一些相当简单的方法来“展开”YAML文档,它可能就可以了。 最佳答案
我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我
Devise是一个Ruby库,它为我提供了这个User类:classUser当写入:confirmable时,注册时会发送一封确认邮件。上周我不得不批量创建300个用户,所以我在恢复之前注释掉了:confirmable几分钟。现在我正在为用户批量创建创建一个UI,因此我需要即时添加/删除:confirmable。(我也可以直接修改Devise的源码,但我宁愿不去调和它)问题:如何即时添加/删除:confirmable? 最佳答案 WayneConrad的解决方案:user=User.newuser.skip_confirmation
我有一个数组数组,想将元素附加到子数组。+=做我想做的,但我想了解为什么push不做。我期望的行为(并与+=一起工作):b=Array.new(3,[])b[0]+=["apple"]b[1]+=["orange"]b[2]+=["frog"]b=>[["苹果"],["橙子"],["Frog"]]通过推送,我将推送的元素附加到每个子数组(为什么?):a=Array.new(3,[])a[0].push("apple")a[1].push("orange")a[2].push("frog")a=>[[“苹果”、“橙子”、“Frog”]、[“苹果”、“橙子”、“Frog”]、[“苹果”、“
有没有办法让Ruby能够做这样的事情?classPlane@moved=0@x=0defx+=(v)#thisiserror@x+=v@moved+=1enddefto_s"moved#{@moved}times,currentxis#{@x}"endendplane=Plane.newplane.x+=5plane.x+=10putsplane.to_s#moved2times,currentxis15 最佳答案 您不能在Ruby中覆盖复合赋值运算符。任务在内部处理。您应该覆盖+,而不是+=。plane.a+=b与plane.a=
出于某种原因,heroku尝试要求dm-sqlite-adapter,即使它应该在这里使用Postgres。请注意,这发生在我打开任何URL时-而不是在gitpush本身期间。我构建了一个默认的Facebook应用程序。gem文件:source:gemcuttergem"foreman"gem"sinatra"gem"mogli"gem"json"gem"httparty"gem"thin"gem"data_mapper"gem"heroku"group:productiondogem"pg"gem"dm-postgres-adapter"endgroup:development,:t