- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 android 应用程序有问题,不知道如何解决....我正在尝试建立连接并抛出我的外部数据库(postgreSQL)并在那里获取一些信息......我在 Java 上编写了一些代码并且连接工作正常(我也能够进行一些查询并接收结果)!问题是,如果我将我在 java 类上编写的代码导入我的 android 应用程序,它会抛出一个我不理解的错误....
05-18 16:09:10.273: W/System.err(5395): org.postgresql.util.PSQLException: Something unusual has occured to cause the driver to fail. Please report this exception.
05-18 16:09:10.273: W/System.err(5395): at org.postgresql.Driver.connect(Driver.java:287)
05-18 16:09:10.273: W/System.err(5395): at java.sql.DriverManager.getConnection(DriverManager.java:175)
05-18 16:09:10.273: W/System.err(5395): at java.sql.DriverManager.getConnection(DriverManager.java:209)
05-18 16:09:10.273: W/System.err(5395): at com.mlab.android.basicoverlays.PostgreSQL.setConnection(PostgreSQL.java:55)
05-18 16:09:10.273: W/System.err(5395): at com.mlab.android.basicoverlays.PostgreSQL.<init>(PostgreSQL.java:18)
05-18 16:09:10.273: W/System.err(5395): at com.example.basicmaponline.MainActivity.onCreate(MainActivity.java:31)
05-18 16:09:10.273: W/System.err(5395): at android.app.Activity.performCreate(Activity.java:5250)
05-18 16:09:10.273: W/System.err(5395): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1097)
05-18 16:09:10.283: W/System.err(5395): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2210)
05-18 16:09:10.283: W/System.err(5395): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2296)
05-18 16:09:10.283: W/System.err(5395): at android.app.ActivityThread.access$700(ActivityThread.java:151)
05-18 16:09:10.283: W/System.err(5395): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1281)
05-18 16:09:10.283: W/System.err(5395): at android.os.Handler.dispatchMessage(Handler.java:99)
05-18 16:09:10.283: W/System.err(5395): at android.os.Looper.loop(Looper.java:137)
05-18 16:09:10.283: W/System.err(5395): at android.app.ActivityThread.main(ActivityThread.java:5293)
05-18 16:09:10.283: W/System.err(5395): at java.lang.reflect.Method.invokeNative(Native Method)
05-18 16:09:10.283: W/System.err(5395): at java.lang.reflect.Method.invoke(Method.java:511)
05-18 16:09:10.283: W/System.err(5395): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
05-18 16:09:10.283: W/System.err(5395): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
05-18 16:09:10.283: W/System.err(5395): at dalvik.system.NativeStart.main(Native Method)
05-18 16:09:10.283: W/System.err(5395): Caused by: android.os.NetworkOnMainThreadException
05-18 16:09:10.293: W/System.err(5395): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1118)
05-18 16:09:10.293: W/System.err(5395): at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
05-18 16:09:10.293: W/System.err(5395): at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
05-18 16:09:10.293: W/System.err(5395): at java.net.InetAddress.getByName(InetAddress.java:289)
05-18 16:09:10.293: W/System.err(5395): at java.net.InetSocketAddress.<init>(InetSocketAddress.java:105)
05-18 16:09:10.293: W/System.err(5395): at java.net.InetSocketAddress.<init>(InetSocketAddress.java:90)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.core.PGStream.<init>(PGStream.java:60)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:101)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:64)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.jdbc2.AbstractJdbc2Connection.<init>(AbstractJdbc2Connection.java:136)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.jdbc3.AbstractJdbc3Connection.<init>(AbstractJdbc3Connection.java:29)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.jdbc3g.AbstractJdbc3gConnection.<init>(AbstractJdbc3gConnection.java:21)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.jdbc4.AbstractJdbc4Connection.<init>(AbstractJdbc4Connection.java:31)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.jdbc4.Jdbc4Connection.<init>(Jdbc4Connection.java:24)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.Driver.makeConnection(Driver.java:393)
05-18 16:09:10.293: W/System.err(5395): at org.postgresql.Driver.connect(Driver.java:267)
05-18 16:09:10.293: W/System.err(5395): ... 19 more
P.S: 我下载了 .jar("postgresql-9.2-1002.jdbc4.jar") 扔到 postgreSQL 网站上,我把它包含在我的 android 项目中......我的 java 版本是“java 版本”1.6.0_45“.请帮助。 :/
我确实尝试过 ActiveSync 类,但它似乎不起作用,我也不知道......
//@SuppressWarnings("rawtypes")
public class loadDatabase extends AsyncTask<Void, Void, HashMap>{
@Override
protected HashMap doInBackground(Void... params) {
// TODO Auto-generated method stub
HashMap<String,SQLloja>listaLojas = new HashMap<String, SQLloja>();
try{
PostgreSQL pSQL = new PostgreSQL(host,database,username,password);
String sql = pSQL.getLojasCidadao();
Statement st = pSQL.getConnection().createStatement();
ResultSet rs = st.executeQuery(sql);
while(rs.next()){
int lcId = Integer.parseInt(rs.getString(1));
String lcNome=rs.getString(2);
String lcCP = rs.getString(3);
int lcDistrito = Integer.parseInt(rs.getString(4));
int lcConselho = Integer.parseInt(rs.getString(5));
double lcAltitude = Double.parseDouble(rs.getString(6));
double lcLongitude = Double.parseDouble(rs.getString(7));
String lcTelefone = rs.getString(8);
boolean lcEstado = Boolean.parseBoolean(rs.getString(9));
String lcRua = rs.getString(10);
SQLloja loja = new SQLloja(lcId,lcNome,lcCP,lcDistrito,lcConselho,lcAltitude,lcLongitude,lcTelefone,lcEstado,lcRua);
listaLoja.put(loja.getNome(),loja.clone());
String informacoesLoja = "Rua : "+lcRua+"\nC.P. : "+lcCP+"\nTel. : "+lcTelefone;
Log.d("ASYNC",lcNome+" Altitude = "+lcAltitude+" Longitude = "+lcLongitude+" Rua = "+lcRua);
}
//listaLoja = new SQLlistLoja(listaLojas);
rs.close();
st.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
if(listaLoja!=null){
for(SQLloja loja : listaLoja.values()){
Log.d("ASYNC", loja.getNome() );
}
}
else Log.d("ASYNC","listaLoja = null ! PQP !");
return listaLojas;
}
@Override
protected void onPostExecute(HashMap listaLojas){
listaLoja = listaLojas;
}
}
即使是:
if(listaLoja!=null){
for(SQLloja loja : listaLoja.values()){
Log.d("ASYNC", loja.getNome() );
}
}
else Log.d("ASYNC","listaLoja = null ! PQP !");
它告诉我 listaLoja 可以为 null ... 通常情况下,它不应该为 null ... 由于我的 doBackground 方法(它从我的外部数据库获取信息并将它们放在我的 listaLoja ...
:/
/编辑后的帖子/
简介.java:
public class Intro extends Activity{
//SQLlistLoja listaLoja;
HashMap<String, SQLloja> listaLoja;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.intro);
//Intent openMainActivity = new Intent("com.example.basicmaponline.MAINACTIVITY"); //isto vem do ficheiro AndroidManifest.xml o "com.example....."
//startActivity(openMainActivity);
try {
listaLoja = new loadDatabase().execute().get();
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (ExecutionException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
最佳答案
当您在主 UI 线程上运行网络相关操作时发生 NetworkOnMainThread 异常。
为此你应该使用异步任务
http://developer.android.com/reference/android/os/AsyncTask.html
检查上面的链接,尤其是“4 个步骤”标题下的主题。
例子:
class TheTask extends AsyncTask<Void,Void,Void>
{
protected void onPreExecute()
{ super.onPreExecute();
//display progressdialog.
}
protected void doInBackground(Void ...params)
{
//Network related opearaiton. Do not update ui here
return null;
}
protected void onPostExecute(Void result)
{
super.onPostExecute(result);
//dismiss progressdialog.
//update ui
}
}
您也可以创建自己的线程。但是您需要确保在 UI 线程上更新 UI。
关于java - 尝试将外部数据库 (postgreSQL) 与我的 android 应用程序连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16625878/
我是 C 语言新手,我编写了这个 C 程序,让用户输入一年中的某一天,作为返回,程序将输出月份以及该月的哪一天。该程序运行良好,但我现在想简化该程序。我知道我需要一个循环,但我不知道如何去做。这是程序
我一直在努力找出我的代码有什么问题。这个想法是创建一个小的画图程序,并有红色、绿色、蓝色和清除按钮。我有我能想到的一切让它工作,但无法弄清楚代码有什么问题。程序打开,然后立即关闭。 import ja
我想安装screen,但是接下来我应该做什么? $ brew search screen imgur-screenshot screen
我有一个在服务器端工作的 UDP 套接字应用程序。为了测试服务器端,我编写了一个简单的 python 客户端程序,它发送消息“hello world how are you”。服务器随后应接收消息,将
我有一个 shell 脚本,它运行一个 Python 程序来预处理一些数据,然后运行一个 R 程序来执行一些长时间运行的任务。我正在学习使用 Docker 并且我一直在运行 FROM r-base:l
在 Linux 中。我有一个 c 程序,它读取一个 2048 字节的文本文件作为输入。我想从 Python 脚本启动 c 程序。我希望 Python 脚本将文本字符串作为参数传递给 c 程序,而不是将
对于一个类,我被要求编写一个 VHDL 程序,该程序接受两个整数输入 A 和 B,并用 A+B 替换 A,用 A-B 替换 B。我编写了以下程序和测试平台。它完成了实现和行为语法检查,但它不会模拟。尽
module Algorithm where import System.Random import Data.Maybe import Data.List type Atom = String ty
我想找到两个以上数字的最小公倍数 求给定N个数的最小公倍数的C++程序 最佳答案 int lcm(int a, int b) { return (a/gcd(a,b))*b; } 对于gcd,请查看
这个程序有错误。谁能解决这个问题? Error is :TempRecord already defines a member called 'this' with the same paramete
当我运行下面的程序时,我在 str1 和 str2 中得到了垃圾值。所以 #include #include #include using namespace std; int main() {
这是我的作业: 一对刚出生的兔子(一公一母)被放在田里。兔子在一个月大时可以交配,因此在第二个月的月底,每对兔子都会生出两对新兔子,然后死去。 注:在第0个月,有0对兔子。第 1 个月,有 1 对兔子
我编写了一个程序,通过对字母使用 switch 命令将十进制字符串转换为十六进制,但是如果我使用 char,该程序无法正常工作!没有 switch 我无法处理 9 以上的数字。我希望你能理解我,因为我
我是 C++ 新手(虽然我有一些 C 语言经验)和 MySQL,我正在尝试制作一个从 MySQL 读取数据库的程序,我一直在关注这个 tutorial但当我尝试“构建”解决方案时出现错误。 (我正在使
仍然是一个初学者,只是尝试使用 swift 中的一些基本函数。 有人能告诉我这段代码有什么问题吗? import UIKit var guessInt: Int var randomNum = arc
我正在用 C++11 编写一个函数,它采用 constant1 + constant2 形式的表达式并将它们折叠起来。 constant1 和 constant2 存储在 std::string 中,
我用 C++ 编写了这段代码,使用运算符重载对 2 个矩阵进行加法和乘法运算。当我执行代码时,它会在第 57 行和第 59 行产生错误,非法结构操作(两行都出现相同的错误)。请解释我的错误。提前致谢:
我是 C++ 的初学者,我想编写一个简单的程序来交换字符串中的两个字符。 例如;我们输入这个字符串:“EXAMPLE”,我们给它交换这两个字符:“E”和“A”,输出应该类似于“AXEMPLA”。 我在
我需要以下代码的帮助: 声明 3 个 double 类型变量,每个代表三角形的三个边中的一个。 提示用户为第一面输入一个值,然后 将用户的输入设置为您创建的代表三角形第一条边的变量。 将最后 2 个步
我是新来的,如果问题不好请见谅 任务:将给定矩阵旋转180度 输入: 1 4 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 输出: 16 15 14 13 12 11
我是一名优秀的程序员,十分优秀!