首页
\
问答
\
如何在tomcat中使用maven在Spring MVC中集成apache solr(How to integrate apache solr in spring MVC using maven on tomcat)
如何在tomcat中使用maven在Spring MVC中集成apache solr(How to integrate apache solr in spring MVC using maven on tomcat)
我正在开发一个使用Spring MVC的Web应用程序,并且我使用tomcat托管了这个应用程序。 我有要求将apache-solr集成到我的搜索引擎的要求。
我试着在互联网上寻找各种教程,但找不到合适的解释步骤。
所以我的要求是
- 如何使用Maven依赖关系在Spring MVC中集成apache solr (我正在使用tomcat来托管服务器)
- 使用solr添加数据文件的基本教程
- 我怎样才能整合它从我的数据库中提取数据。 我正在使用休眠映射我的数据库表。
经过一些教程后,我认为spring-data-solr适用于Spring MVC。
PS我是所有上述技术的新手。
I am developing a web application using spring MVC and I have hosted this using tomcat. I have a requirement where I want to integrate apache-solr to my search engine.
I tried looking on internet for various tutorials but couldn't find a proper one to explain the steps.
So my requirements are
- How to integrate apache solr in spring MVC using maven dependency(I am using tomcat to host the server)
- Basic tutorials to add data files with solr
- How can I integrate it to pick up the data from my database. I am using hibernate to map my database tables.
After going through some tutorials I think spring-data-solr is suitable for spring MVC.
P.S. I am new to all the above technologies.
原文:https://stackoverflow.com/questions/27124285
更新时间:2022-04-29 17:04
最满意答案
首先,声明这个asynctask类:
class MyTask extends AsyncTask<String,Void,Bitmap>{ @Override protected Bitmap doInBackground(String... strings) { String myString = Params[0]; try { URL url = new URL(myString); Bitmap myBitmap = BitmapFactory.decodeStream(url.openConnection().getInputStream()); return myBitmap; } catch (IOException e) { e.printStackTrace(); return null; } return null; } @Override protected void onPostExecute(Bitmap bitmap) { super.onPostExecute(bitmap); imgDisplay.setImageBitmap(bitmap); } }
您的zoomActivity更改为:
public class ZoomActivity extends Activity { ImageView imgDisplay; @SuppressLint("NewApi") @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_zoom); Intent intent = getIntent(); String url2 = intent.getStringExtra("image"); Button btnClose; imgDisplay = (ImageView) findViewById(R.id.imgDisplay); btnClose = (Button) findViewById(R.id.btnClose); //call asynctask new MyTask().execute(url2); btnClose.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { ZoomActivity.this.finish(); } }); }
希望这有效
First, declare this asynctask class:
class MyTask extends AsyncTask<String,Void,Bitmap>{ @Override protected Bitmap doInBackground(String... strings) { String myString = Params[0]; try { URL url = new URL(myString); Bitmap myBitmap = BitmapFactory.decodeStream(url.openConnection().getInputStream()); return myBitmap; } catch (IOException e) { e.printStackTrace(); return null; } return null; } @Override protected void onPostExecute(Bitmap bitmap) { super.onPostExecute(bitmap); imgDisplay.setImageBitmap(bitmap); } }
Your zoomActivity changes to:
public class ZoomActivity extends Activity { ImageView imgDisplay; @SuppressLint("NewApi") @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_zoom); Intent intent = getIntent(); String url2 = intent.getStringExtra("image"); Button btnClose; imgDisplay = (ImageView) findViewById(R.id.imgDisplay); btnClose = (Button) findViewById(R.id.btnClose); //call asynctask new MyTask().execute(url2); btnClose.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { ZoomActivity.this.finish(); } }); }
hope this works
相关问答
更多-
Android:异步任务:doInBackground在动作回调之前返回(Android: Async Task : doInBackground returns before an action callback)[2024-03-17]
快速解决方案是阻止异步任务完成,例如使用Semaphore : protected String doInBackground(String... params) { String clientId = generateClientId(); MqttAndroidClient client = // .... Semaphore s = new Semaphore(0); try { IMqttToken token = cl ... -
AsyncTask:doInBackground()的返回值在哪里?(AsyncTask: where does the return value of doInBackground() go?)[2022-09-26]
该值可以在onPostExecute中使用 ,您可能需要覆盖才能使用该结果。 以下是Google文档的示例代码段: private class DownloadFilesTask extends AsyncTask{ protected Long doInBackground(URL... urls) { int count = urls.length; long totalSize = 0; ... -
问题是当你调用hh.initialize() ,你已经在后台线程中,现在创建一个Handler已经太晚了。 实际上,您的代码正在尝试从后台线程中执行大量UI工作。 您应该将UI线程外部实际需要完成的内容分离到一个单独的方法中,并且只从AsyncTask的doInBackground中调用该方法。 The problem is that when you call hh.initialize(), you are already in the background thread and it is too l ...
-
更改 finally { scanner.close(); connectStat.disconnect(); } 至 finally { if(null != scanner){ scanner.close();} if(null != connectStat){ connectStat.disconnect();} } 我猜测在初始化扫描程序之前会抛出异常因此会出现空指针异常。 黄金法则,总是检查null change finally { scanner.clo ...
-
Logcat错误: 引起:android.view.ViewRootImpl $ CalledFromWrongThreadException:只有创建视图层次结构的原始线程才能触及其视图。 你尝试在doInBackground使用UI线程, content.setText("fail"); 你不能在后台线程中使用onPostExecute触摸ui线程中的任何东西来处理UI 这是你想要的一个样本。 private class DownloadWebPageTask extends AsyncTask这取决于您声明异步任务的方式和位置。 但是如果在Activity中声明并调用它,你应该在asynctask中添加一个构造函数来获取url。 然后将其称为new MyAsyncTask(next).execute(); 。 在此之前你应该使String next = "first url"; 您的Activity的私有变量。 在getData()更改String next = page.getString("nextpage"); to next = page.getString("nextpage"); 。 ...首先,声明这个asynctask类: class MyTask extends AsyncTask
{ @Override protected Bitmap doInBackground(String... strings) { String myString = Params[0]; try { URL url = new URL(myString); Bitmap my ... 是的,可能方法client.connect()创建一个ASyncTask,这使您的任务继续执行,结束方法并转到onPostExecute。 如果是这种情况,您使用的API应该有一些方法来监听异步消息。 API应该有一些将在您的线程中触发的Listener或Callback。 编辑:我在互联网上搜索WebViewClient,方法connect()确实创建了一个新的线程,你应该看看如何正确使用调用。 Yes, probably the method client.connect() creates a ASy ...永远不会调用onPostExecute,但doInBackground会返回值(onPostExecute is never called but doInBackground returns value)[2021-07-26]
您需要在AsyncTask之外分配视图。 在后台执行do后,在另一个线程上调用onPostExecute。 在此之前,主线程已到达您分配OnItemClickListener的行。 只需移动线条 searchView = (SearchView) findViewById(R.id.searchView); listView = (ListView) findViewById(R.id.listView); 在AsyncTask之外。 you need to assign the views outsid ...AsyncTask API: http : //developer.android.com/reference/android/os/AsyncTask.html 阅读上面的文档后,很明显AsyncTask在2.3.3版本中应该可以正常工作(它在API 3 = Android 1.5中添加)。 你确定正确的参数传递了吗? 下面是一个简单的异步任务示例,它调用WebService并在活动的TextView中显示结果,我希望这可以帮助您进入正确的轨道: private class AsyncTaskWebSer ...相关文章
更多- Spring MVC 3 深入总结
- Spring MVC文件上传
- Running Solr with Maven
- 使用Maven运行Solr(翻译)
- Spring MVC 入门实例教程
- maven+springMvc+velocity
- apache solr之我们的应用
- 在Tomcat部署Solr 4.3
- Solr在Tomcat中的部署
- 在Tomcat下简单搭建Solr
最新问答
更多- 您如何使用git diff文件,并将其应用于同一存储库的副本的本地分支?(How do you take a git diff file, and apply it to a local branch that is a copy of the same repository?)
- 将长浮点值剪切为2个小数点并复制到字符数组(Cut Long Float Value to 2 decimal points and copy to Character Array)
- OctoberCMS侧边栏不呈现(OctoberCMS Sidebar not rendering)
- 页面加载后对象是否有资格进行垃圾回收?(Are objects eligible for garbage collection after the page loads?)
- codeigniter中的语言不能按预期工作(language in codeigniter doesn' t work as expected)
- 在计算机拍照在哪里进入
- 使用cin.get()从c ++中的输入流中丢弃不需要的字符(Using cin.get() to discard unwanted characters from the input stream in c++)
- No for循环将在for循环中运行。(No for loop will run inside for loop. Testing for primes)
- 单页应用程序:页面重新加载(Single Page Application: page reload)
- 在循环中选择具有相似模式的列名称(Selecting Column Name With Similar Pattern in a Loop)
- System.StackOverflow错误(System.StackOverflow error)
- KnockoutJS未在嵌套模板上应用beforeRemove和afterAdd(KnockoutJS not applying beforeRemove and afterAdd on nested templates)
- 散列包括方法和/或嵌套属性(Hash include methods and/or nested attributes)
- android - 如何避免使用Samsung RFS文件系统延迟/冻结?(android - how to avoid lag/freezes with Samsung RFS filesystem?)
- TensorFlow:基于索引列表创建新张量(TensorFlow: Create a new tensor based on list of indices)
- 企业安全培训的各项内容
- 错误:RPC失败;(error: RPC failed; curl transfer closed with outstanding read data remaining)
- C#类名中允许哪些字符?(What characters are allowed in C# class name?)
- NumPy:将int64值存储在np.array中并使用dtype float64并将其转换回整数是否安全?(NumPy: Is it safe to store an int64 value in an np.array with dtype float64 and later convert it back to integer?)
- 注销后如何隐藏导航portlet?(How to hide navigation portlet after logout?)
- 将多个行和可变行移动到列(moving multiple and variable rows to columns)
- 提交表单时忽略基础href,而不使用Javascript(ignore base href when submitting form, without using Javascript)
- 对setOnInfoWindowClickListener的意图(Intent on setOnInfoWindowClickListener)
- Angular $资源不会改变方法(Angular $resource doesn't change method)
- 在Angular 5中不是一个函数(is not a function in Angular 5)
- 如何配置Composite C1以将.m和桌面作为同一站点提供服务(How to configure Composite C1 to serve .m and desktop as the same site)
- 不适用:悬停在悬停时:在元素之前[复制](Don't apply :hover when hovering on :before element [duplicate])
- 常见的python rpc和cli接口(Common python rpc and cli interface)
- Mysql DB单个字段匹配多个其他字段(Mysql DB single field matching to multiple other fields)
- 产品页面上的Magento Up出售对齐问题(Magento Up sell alignment issue on the products page)