- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我写了一个 Android 游戏。现在,我想连接玩家的标记。
下面的代码是客户端程序,它将他们的名字、国家和标记发送到服务器。基本上,我使用“:”来分隔信息。
但是黑客可以通过反编译.apk文件知道我的服务器ip和端口。然后,他们可以创建一个基本的 Java 应用程序来访问我的服务器。他们可以给我发送“hacker:badserver:123456789”。最后,顶部标记变为“123456789”。
连接用户数据是否更安全?
Socket client = new Socket(ip, port);
OutputStream outToServer = client.getOutputStream();
DataOutputStream out = new DataOutputStream(outToServer);
out.writeUTF("Hacker:HK:3910");
最佳答案
黑客不需要 APK 来确定您服务器的 IP。他们可以简单地使用代理工具,例如 Fiddler 或数据包嗅探器。
在我作为游戏开发者的短暂工作期间(致力于网络多人游戏功能),您学会了假设作弊者和黑客拥有您游戏的源代码。然后围绕该假设设计协议(protocol)。
那么如何保护您的服务器不被流氓客户端攻击或作弊呢?你真的不能,但有些事情让它变得非常困难。
要求用户在允许游戏向您的服务器发布任何内容之前“登录”(名称/密码)。如果您发现有人作弊,请通过禁止他们登录来禁止他们的帐户玩游戏。在每个 HTTP 请求的 header 中使用“票证”或身份验证 token ,以便服务器进行验证。如果您禁止某人,他们将无法获得新帐户再试一次。
HTTPS 而不是 HTTP。从技术上讲,黑客可以通过简单地将他的流氓客户端更改为也使用 HTTPS 进行发布来解决这个问题。他可以通过调试您的 APK 来对协议(protocol)进行逆向工程。但是现在你让他更难发现协议(protocol)是从什么开始的。使用 HTTPS,黑客无法使用 Fiddler 等简单工具来观察网络流量。
警惕发布版本中的大量调试。确保与任何协议(protocol)相关的“日志”语句仅在调试版本中,从不发布版本。
混淆一切并使用类似 HMAC 的东西用 key “签署”每条消息。这在技术上不是安全的,但会使任何破坏加密的人继续下去变得更加困难。类似于以下内容:
例子代码:
name = BASE64("Hacker");
messagetype = ROT13("HK");
score = 3910;
tosend = name + ":" + messagetype + ":" + Integer.ToString(score ^ 0xAAAAAAAA) + ":";
Mac mac = Mac.getInstance(HMAC_SHA1_ALGORITHM);
mac.init(Your_Secret_Key);
byte[] rawHmac = mac.doFinal(data.getBytes());
tosend += Encoding.EncodeBase64(rawHmac);
“Your_Secrey_Key”在您的源代码中的某处进行了编码,并且仅在运行时解密。
以上将生成类似于以下内容的字符串:
SGFja2Vy:UX:AAAAA5EC:blahblahxyxunreadable
相应的服务器代码将解码消息并在接受之前使用 key 进行验证。
这是完美的安全性吗?没有。
我应该使用这些技术构建电子商务解决方案吗?绝对不是。
这些技术是否可以阻止 99% 的黑客尝试作弊?绝对地。
它是否击败了不惜一切代价赢得高分的最坚定的黑客?也许不会。但是“努力返回”的比率上升了。这可能不值得他们花时间。
希望这对您有所帮助。
关于java - (Android) 通过一个简单的套接字攻击服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24532340/
谁能解释一下 Server.MapPath(".")、Server.MapPath("~")、Server.MapPath(@"之间的区别\") 和 Server.MapPath("/")? 最佳答案
我不知道,为什么我们要使用 Server.UrlEncode() & Server.UrlDecode()?!在 QueryString 中我们看到 URL 中的任何内容,那么为什么我们要对它们进行编
我已经通过 WHM 在我的一个域上安装了 ssl 证书。网站正在使用 https://xyz.com . 但是它不适用于 https://www.xyz.com .我已经检查了证书,它也适用于 www
我已经使用 WMI 检测操作系统上是否存在防病毒软件,itz 正常工作并通过使用命名空间向我显示防病毒信息,例如 win xp 和 window7 上的名称和实例 ID:\root\SecurityC
我们有 hive 0.10 版本,我们想知道是否应该使用 Hive Server 1 或 Hive Server2。另一个问题是连接到在端口 10000 上运行的 Hive 服务器,使用 3rd 方工
我想在 C++ 中使用 Windows Server API 设置一个 HTTPS 服务器,我使用了示例代码,它在 HTTP 上工作正常,但我就是不能让它在 HTTPS 上工作。 (我不想要客户端 S
我写了一个非常基本的类来发送电子邮件。我用 smtp 服务器对其进行了测试,它工作正常,但是当我尝试使用我公司的交换服务器时,它给出了这个异常: SMTP 服务器需要安全连接或客户端未通过身份验证。服
我的应用程序包含一个“网关”DataSnap REST 服务器,它是所有客户端的第一个访问点。根据客户端在请求中传递的用户名(基本身份验证),请求需要重定向到另一个 DataSnap 服务器。我的问题
我有一个 Tomcat 服务器和一个 Glassfish4 服务器。我的 Servlet 在 Tomcat 服务器上启动得很好,但在 Glassfish4 服务器上给我一个“HTTP Status 4
我在 vmware 上创建了一个 ubuntu 服务器。我用它作为文件服务器。如果我通过托管虚拟机的计算机进行连接,则可以访问它。我无法从同一网络上的其他计算机执行此操作。提前致谢! 最佳答案 首先确
如何重启 Rails 服务器?我从 开始 rails server -d 所以服务器是分离的 我知道的唯一方法就是去做ps 辅助 | grep rails 并 kill -9关于过程#但是像这样杀死进
我实际上正在尝试找到编写一个简单的 XMPP 服务器的最佳方法,或者找到一个占用空间非常小的服务器。我只关心XMPP的核心功能(状态、消息传递、群组消息传递)。目前还在学习 XMPP 协议(proto
我实际上正在尝试找到编写简单 XMPP 服务器的最佳方法,或者找到一个占用空间非常小的方法。我只关心 XMPP 的核心功能(统计、消息、组消息)。目前也在学习 XMPP 协议(protocol),所以
我们正在尝试从 Java JAX-RS 适配器访问 SOAP 1.1 Web 服务。 我们正在使用从 WSDL 生成的 SOAP 客户端。 但是当解码 SOAP 故障时,我们得到以下异常: ... C
目前,我和许多其他人正在多个平台(Windows、OS X 和可能的 Linux)上使用 Python HTTP 服务器。我们正在使用 Python HTTP 服务器来测试 JavaScript 游戏
我有一个连续运行的服务器程序(C#/.NET 2.0 on Linux with mono),我想从 PHP 脚本连接到它以在网站上显示状态信息。 目的是创建一个(某种)实时浏览器游戏(无 Flash
所以我有一个单页客户端应用程序。 正常流程: 应用程序 -> OAuth2 服务器 -> 应用程序 我们有自己的 OAuth2 服务器,因此人们可以登录应用程序并获取与用户实体关联的 access_t
我们刚刚将测试 Web 服务器从 Server 2008 升级到 Server 2012 R2。我们有一个部署我们网站的批处理脚本。当它将站点推送到服务器时,它现在失败了。奇怪的是,我可以使用相同的发
建议一些加载SpagoBI服务器的方法,我尝试了所有方法来解析spagobi服务器。在 Catalina 中,错误是 - * SEVERE: Unable to process Jar entry [
当我们点击应用程序服务器(apache tomcat)时,它会创建一个线程来处理我们的请求并与 tomcat 连接,建立连接,tomcat 创建另一个线程来处理请求并将其传递给连接,连接线程将其传递给
我是一名优秀的程序员,十分优秀!