我正在创建开源应用程序,其中一个类需要隐藏在开源中。当人们看到我的代码时,我不需要看到这个类。我怎样才能做到这一点?也许我可以制作这个类的jar文件?
答案 0 :(得分:4)
如果你正在隐藏一个类,它不是真正的开源。如果需要对最终用户的代码进行模糊处理,您可能应该重新考虑如何发布此代码。
答案 1 :(得分:0)
我可以看到这样做的唯一原因是不会发布用于签署商店上发布的官方应用程序的加密密钥。在这种情况下,我根本不会将文件提交到存储库中,而是将其存储在其他位置。
答案 2 :(得分:0)
嗯,如果你隐藏任何东西,它不是真正的开源,但是:
我建议使用异步任务并将HTTP请求发送到PHP文件,然后再发送JSON响应。您可以使用以下内容解释它:
package jsonparse.pkg;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONException;
import org.json.JSONObject;
import android.util.Log;
public class JSONParser {
static InputStream is = null;
static JSONObject jObj = null;
static String json = "";
// constructor
public JSONParser() {
}
public JSONObject getJSONFromUrl(String url) {
// Making HTTP request
try {
// defaultHttpClient
DefaultHttpClient httpClient = new DefaultHttpClient();
HttpPost httpPost = new HttpPost(url);
HttpResponse httpResponse = httpClient.execute(httpPost);
HttpEntity httpEntity = httpResponse.getEntity();
is = httpEntity.getContent();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
try {
BufferedReader reader = new BufferedReader(new InputStreamReader(
is, "iso-8859-1"), 8);
StringBuilder sb = new StringBuilder();
String line = null;
while ((line = reader.readLine()) != null) {
sb.append(line + "\n");
}
is.close();
json = sb.toString();
} catch (Exception e) {
Log.e("Buffer Error", "Error converting result " + e.toString());
}
// try parse the string to a JSON object
try {
jObj = new JSONObject(json);
} catch (JSONException e) {
Log.e("JSON Parser", "Error parsing data " + e.toString());
}
// return JSON String
return jObj;
}
}
这样他们就看不到php文件了。
你可以用加密的JS文件做同样的事情,我不知道该怎么做。