热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

安卓手机移动端Web开发调试之Chrome远程调试(RemoteDebugging)

一、让安卓打debug模式的apk包二、将电脑中的chrome升级到最新版本,在chrome浏览器地址栏中输入chrome:inspect#devices;在智能手机还未普及时,移动设备

一、让安卓打debug模式的apk包

二、将电脑中的chrome升级到最新版本,在chrome浏览器地址栏中输入chrome://inspect/#devices;

在智能手机还未普及时,移动设备的调试处处是alert的,这估计是最常用的办法了。以前很多时候为了预览页面在移动设备上的效果,需要先将页面上传到测试服务器,再将url输入到设备浏览器,或者使用第三方二维码扫码应用,通过移动设备访问打开浏览实际效果,每次换设备都要重复这些操作,页面多的话这些繁琐的事情就特别让人厌烦了。移动互联网的浪潮,伴随着智能硬件的兴起与移动设备的普及,让前端工程师这个职业变得更为专业,前端工程师要做的工作也越来越多,尤其是国内大大小小众多的手机厂商的兴起、手机型号的繁多,仅仅依靠Firebug与Chrome/Safari自带的debug工具已经远远难以满足需求了。繁琐重复性劳动占用了相当的时间,庆幸的是前端的自动化工具也越来越多。越来越多的便捷调试工具无非是前端工程师的一大福音。

 

近几年,浏览器厂商也纷纷推出自己的远程调试(RemoteDebugging)工具,比如Opera Mobile 可以借助其推出的跨设备跨平台桌面开发者工具Opera Dragonfly 实现远程调试,iOS Safari 可以开启Web检查器在 Mac OS X系统中实现远程调试。Android 4+已上系统的 Chrome for Android可以 配合 ADB(Android Debug Bridge)实现桌面远程调试,桌面版Chrome 32+已经支持免安装ADB即可实现远程调试移动设备页面/WebView 。国内的UC浏览器开发者版也推出了自己的远程调试工具RemoteInspector(简称RI)。

 

除了浏览器厂商之外,也涌现出许多第三方开发的远程调试工具,诸如支持全平台调试的Weinre 和Adobe Edge Inspect CC,国人自研的iOS专用工具MIHTool。

 

本篇主要说一下Chrome RemoteDebugging 的方法,之前也遇到一些坑,自己总结了一些经验,分享如下。

 

Chrome DevTools调试移动设备Brower Page Tabs/WebViews

 

安卓远程调试目前支持所有操作系统(Windows,Mac, Linux, and Chrome OS.)中调试,支持

● 调试站点的页面

● 调试安卓原生App中的WebView

● 实时将安卓设备的屏幕图像同步显示到开发机器。

● 通过端口转发(port forwarding)与虚拟主机映射(virtual host mapping)实现安卓移动设备与开发服务器进行交互调试。

 

调试要求:

● 开发环境安卓桌面版Chrome32+

● 一条USB数据线,连接电脑与移动设备,安装相应机型的USB驱动。驱动程序下载地址:http://developer.android.com/tools/extras/oem-usb.html

   如果电脑上安装有百度手机助手、360手机助手这类软件,一般连接后可以自动安装相应的USB驱动程序。

● 如果是调试网页,移动设备需要安装Chrome forAndroid ,且安卓系统须为Android 4.0+

● 对于APP WebView的调试,需要系统为Android 4.4+ 并且原生应用内的Webview须进行相应的调试声明配置。

说明:远程调试要求桌面版Chrome浏览器版本要高于安卓移动设备的Chrome版本号。有条件的最好使用Chrome 的金丝雀特别版Chrome Canary (Mac/Windows)或者Chrome桌面开发版Chrome Dev channel release (Linux)。

 

第一步:首先在移动设备上开启USB调试模式。方法:

● Android 3.2+,打开设置 – 应用程序 – 开发,在“USB调试”处打钩选上

● Android 4.0~ Android 4.1 ,打开设置-开发者选项-进入在“USB调试”处打钩选上。

● Android 4.2+,打开设置-关于手机-手机配置信息-连点“版本号”7次,返回上层就可以看到“开发者选项”显示出来了,在“USB调试”处打钩选上。

 

第二步:用USB数据线连接设备,驱动装好连接成功后,你可能会在设备上看到一个弹框请求允许使用这台计算机通过usb调试

 

 

 

 

勾选后点击“确定”。

第三步:在电脑上打开Chrome浏览器的菜单– 更多工具 – 检查设备(Chromemenu > More tools > Inspect Devices),或者直接在浏览器地址栏输入chrome://inspect 或者about:inspect

 

 

打开后DevTools后,确保打钩选中Discover USB devices

 

 

如果USB连接成功,这时候我们可以看到移动设备的型号和设备上运行的页面和允许调试的WebView列表。找到需要调试的目标页面,点击inspect即可打开DevTools,点击reload可重新加载当前的调试页面,点击focus tab可将标签页置顶,close为关闭当前页面。更可以通过在输入框中键入网址新开一个页面。

 

点击inspect打开DevTools后,你可以选中页面中的DOM元素,同时设备中对应元素也高亮显示,也可使用DevTools中的Inspect Element 选中目标元素,可以实时与移动设备页面交互,方便的定位问题所在,进行代码调试。

 

在输入框中输入一个新的网址,点击Opoen可打开你想要调试的新页面。

 

说明:由于Chrome版本不同,DevTools也可能有些差别,比如我的Chrome38.0.2125.104 m版竟然没有打开新页面的url输入框,升级到v39后恢复正常,知道原因的欢迎留言。

1. DevTools窗口使用F5快捷键(CMD+R for Mac)重新加载页面

2. 使用Network面板可以实时观察页面在手机实际网络环境中资源的加载情况。

3. Timeline面板可以用来分析页面渲染和CPU使用情况,通常情况下移动设备的性能会比电脑上要低一些。

4.  在DevTools的Console控制台中编写脚本执行,会同步表现在移动设备中检查的页面。

5. 如果要调试本地搭建的服务器程序,需要用到端口转发和虚拟主机映射,以使设备上可以呈现你本地环境下的页面内容。

 

调试WebView需要满足安卓系统版本为Android 4.4+已上。并且需要再你的APP内配置相应的代码,在WebView类中调用静态方法setWebContentsDebuggingEnabled,如下:

[java]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. if (Build.VERSION.SDK_INT >=Build.VERSION_CODES.KITKAT) {  
  2.   
  3.    WebView.setWebContentsDebuggingEnabled(true);  
  4.   
  5. }  

 

以上配置方法适用于安卓应用内所有的WebView情形。

安卓WebView是否可调试并不取决于应用中manifest的标志变量debuggable,如果你想只在debuggable为true时候允许WebView远程调试,请使用以下代码段:

[java]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. if (Build.VERSION.SDK_INT>= Build.VERSION_CODES.KITKAT) {  
  2.   
  3.     if (0 != (getApplicationInfo().flags &=ApplicationInfo.FLAG_DEBUGGABLE))  
  4.   
  5.     { WebView.setWebContentsDebuggingEnabled(true);}  
  6.   
  7.   }  

 

WebView的可用列表如下:

 

所列信息其中包括页面的title,url地址,页面尺寸大小及其相对于设备屏幕的相对位置。

 

实时屏幕投影(Live screencasting)

 

调试移动设备时视线在两个设备的屏幕之间来回切换太不方便了,screencast实现了移动设备屏幕与开发环境DevTools的同步,你可以通过screencast与移动设备上的内容进行交互式的操作。

 

Screencast只呈现页面的内容,而不显示工具条地址栏、设备键盘等其他设备接口,这些在Screencase中表现为透明部分。

 

Android 4.4,是由Google公司制作和研发的代号为KitKat的手机操作系统,于北京时间2013年9月4日凌晨对外公布了该Android新版本的名称,为Android 4.4(代号 KitKat 奇巧)。据悉,该代号来自雀巢的KitKat巧克力。对于KitKat 4.4.3,screencast不仅可以在Tab网页实现,在WebView上也可以同步交互操作。

 

点击 DevTools右上角的Screencast图标,可以开启Screencast视图,移动设备屏幕会实时展现在左侧的Screencast面板中。

 

 

 

Chrome32+版本的DevTools对连接的设备支持native USB debugging。而版本号稍低的一些则需要通过安装ADB或ADB plugin调试移动设备上的Chrome网页。由于之前一直是使用ADB plugin方式调试,如今一番折腾发现高版本更为方便实用的特性,由于网上的资料比较零散,关键的东西都没有提及,坑也不少,这也正是写此文的缘由。

 

曾经靠安装Android SDK套件,需要执行类似 adb forward tcp:9001 localabstract:chrome_devtools_remote 这样的命令,才能开始调试,现在我们完可以摆脱这些繁琐的命令了。

开发机器安装ADB plugin是Chrome 28+之后的方式,区别于以前需要安装整个Android SDK套件,同时移动设备要安装Chrome for Android 28+。ADB扩展程序安装成功后,Chrome菜单旁边会出现一个灰色的Andr​​oid启动图标。

点击Android的图标,然后单击ADB开始。一旦ADB已经开始,菜单图标变成绿色,并显示当前连接的设备的数量,如果有连接设备的话。

 

点击View inspection Targets打开:列表中会显示每个连接的设备及其选项卡页面。查找要调试的页面,并点击页面链接URL旁边的inspect启动DevTools调试窗口。 

 

使用用DevTools特别重要的一点是:如果你点击inspect打开的DevTools窗口一片空白,且刷新无效时,那极有可能是由于被墙的缘故,你可以尝试appspot.com是否可以ping的通,如果无法ping通,那你现在就先FQ吧(goagent 或红杏都不错,将appspot.com加入白名单),当然你还需要有google账户。

 

补充说明一下,如果接上USB数据线后,没有显示任何连接的设备,请按照以下步骤排查:

● 检查您的设备连接到USB,检查USB数据线。

● 确保您的设备发出ADB设备命令列为可用。如果没有,检查是否有您的设备上是否启用USB调试。

● 若是Windows系统,检查你的USB驱动是否安装正确。参考http://developer.android.com/tools/extras/oem-usb.html

● 桌面Chrome浏览器打开 chrome://inspect检查Discover USB devices是否选中

● 确保桌面浏览器版本要高于移动设备的Chrome版本号

● 如果Chrome for Android版本较低,请检查移动设备上Chrome浏览器设置,确保设置中启用USB调试。高版本中无此设置项,无须设置。

● 如果依然无法显示,尝试重新拔插USB数据线。

 

 

端口转发(Port forwarding)

 

你的手机和开发机器有时会处于两个不同的网络(如本地服务器和线上服务器两个不同的网络环境),手机上可能获取不到开发环境的页面内容。况且,有时候你的开发环境处于公司出于安全原因管控限制下的网络中。

 

Chrome For Android中的端口转发解决了这一困难,在手机上测试你开发的网站瞬间变得容易。它的工作原理是在移动设备上创建一个监听TCP端口,该端口映射到开发机器特定的TCP端口,两个端口通过USB线路通信,所以这种连接并不依赖于所处网络环境的配置。

 

在进入正题前必须要提前说明搭建本地服务器需要注意的一些点。安装本地服务器,这里安装的是wamp集成包。一键安装完成后,需要修改Apache的一些设置。

 

1. 打开Apache安装目录下的配置文件httpd.conf增加监听多个端口。

 

[plain]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. # Listen: Allows you to bindApache to specific IP addresses and/or  
  2. # ports, instead of the default. See also the   
  3. # directive.  
  4. #  
  5. # Change this to Listen on specific IP addresses as shown below to  
  6. # prevent Apache from glomming onto all bound IP addresses.  
  7. #  
  8. #Listen 12.34.56.78:80  
  9. Listen 80  
  10. Listen 8888  
  11.   
  12. Listen 8999  
  13. Listen 1818  

 

开启Apache服务后可通过命令netstat –n –a查看所配置的端口是否开启。

如果你本地环境也开启了IIS服务,为了避免二者都是用80端口发生冲突,可以按照上述方法修改Apache的默认端口。修改设置完成后别忘了重启Apache服务。

如何改变IIS端口:若保留Apache服务与IIS服务同时运行,不想改变Apache默认80端口,那么只能改变IIS端口,方法如下:开始->运行->输入:inetmgr->Internet信息服务->本地计算机->网站->右键“默认网站”->属性->选择“网站”标签->修改TCP端口即可。最后重新启动IIS服务。

 

2. 在httpd.conf文件中开启虚拟主机配置

 

[plain]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. # Virtual hosts  
  2.   
  3. #Includeconf/extra/httpd-vhosts.conf  

将第二行前的#号去掉,即是为了允许加载扩展配置。

 

1.  Apache服务器默认的路径为安装目录下的htdocs,如果想改变默认目录,可以修改httpd.conf文件下的DocumentRoot和Directory,修改两者路径到你指定的目录即可。

[plain]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. #  
  2.   
  3. # DocumentRoot: The directoryout of which you will serve your  
  4.   
  5. # documents. By default, allrequests are taken from this directory, but  
  6.   
  7. # symbolic links and aliasesmay be used to point to other locations.  
  8.   
  9. #  
  10.   
  11. DocumentRoot "E:/wamp/www/"  
  12.   
  13.    
  14.   
  15. #  
  16.   
  17. # This should be changed towhatever you set DocumentRoot to.  
  18.   
  19. #  
  20.   
  21.   

 

打开extra目录下的httpd-vhosts.conf配置文件,在文件最后位置分别为监听的端口设置虚拟主机目录

 

[plain]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. #  
  2.   
  3. # Use name-based virtual hosting.  
  4.   
  5. #  
  6.   
  7. NameVirtualHost *:80  
  8.   
  9.    
  10.   
  11. #  
  12.   
  13. # VirtualHost example:  
  14.   
  15. # Almost any Apache directive may go into a VirtualHostcontainer.  
  16.   
  17. # The first VirtualHost section is used for all requests that donot  
  18.   
  19. # match a ServerName or ServerAlias in any block.  
  20.   
  21. #  
  22.   
  23.   
  24.   
  25.     ServerAdminwebmaster@dummy-host.example.com  
  26.   
  27.     DocumentRoot "E:/wamp/www /dummy-host.example.com"  
  28.   
  29.     ServerName dummy-host.example.com  
  30.   
  31.     ServerAliaswww.dummy-host.example.com  
  32.   
  33.     ErrorLog"logs/dummy-host.example.com-error.log"  
  34.   
  35.     CustomLog"logs/dummy-host.example.com-access.log" common  
  36.   
  37.   
  38.   
  39.    
  40.   
  41.   
  42.   
  43.     ServerAdminwebmaster@dummy-host2.example.com  
  44.   
  45.     DocumentRoot"E:/wamp/www"  
  46.   
  47.     ServerName localhost  
  48.   
  49.     ErrorLog"logs/dummy-host2.example.com-error.log"  
  50.   
  51.     CustomLog"logs/dummy-host2.example.com-access.log" common  
  52.   
  53.   
  54.   
  55.    
  56.   
  57.   
  58.   
  59.     ServerAdminprograms@dummy-host2.example.com  
  60.   
  61.     DocumentRoot"E:/wamp/www/programs"  
  62.   
  63.     ServerName localhost  
  64.   
  65.     ErrorLog"logs/programs-host2.example.com-error.log"  
  66.   
  67.     CustomLog"logs/programs-host2.example.com-access.log" common  
  68.   
  69.   
  70.   
  71.    
  72.   
  73.   
  74.   
  75.     ServerAdminprograms@dummy-host2.example.com  
  76.   
  77.     DocumentRoot"E:/wamp/www/site"  
  78.   
  79.     ServerName localhost  
  80.   
  81.     ErrorLog"logs/programs-host2.example.com-error.log"  
  82.   
  83.     CustomLog"logs/programs-host2.example.com-access.log" common  
  84.   
  85.   
  86.   
  87.    
  88.   
  89.   
  90.   
  91.     ServerAdmin webapp@dummy-host2.example.com  
  92.   
  93.     DocumentRoot"E:/wamp/www/webapp"  
  94.   
  95.     ServerName a.test.com  
  96.   
  97.     ErrorLog"logs/webapp-host2.example.com-error.log"  
  98.   
  99.     CustomLog"logs/webapp-host2.example.com-access.log" common  
  100.   
  101.   



其中a.test.com若要生效还需要在本地host文件中增加映射关系:127.0.0.1 a.test.com

然后我们测试一下,在浏览器输入你配置的主机名和端口号,url指向你要打开的文件。

 

 

若出现上述提示,检查你的虚拟主机目录是否正确。如果目录设置正确,即可打开页面。

 

 

一般情况下目录访问权限默认为:

[plain]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. #  
  2.   
  3. # First, we configure the"default" to be a very restrictive set of  
  4.   
  5. # features.   
  6.   
  7. #  
  8.   
  9.   
  10.   
  11.     Options FollowSymLinks  
  12.   
  13.     AllowOverride All  
  14.   
  15.     Order deny,allow  
  16.   
  17.     Deny from all  
  18.   
  19.   

 

许多人为了方便直接设置为

 

[plain]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. #  
  2.   
  3. # First, we configure the"default" to be a very restrictive set of  
  4.   
  5. # features.   
  6.   
  7. #  
  8.   
  9.   
  10.   
  11.     Options FollowSymLinks  
  12.   
  13.     AllowOverride All  
  14.   
  15.     Order allow ,deny  
  16.   
  17.     Allow from all  
  18.   
  19.   

 

出于安全考虑,根据调试的人员和实际需要,我个人倾向于为特定目录设置不同的权限,示例如下:

 

[plain]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1. #  
  2.   
  3. # First, we configure the"default" to be a very restrictive set of  
  4.   
  5. # features.   
  6.   
  7. #  
  8.   
  9.   
  10.   
  11.     Options FollowSymLinks  
  12.   
  13.     AllowOverride All  
  14.   
  15.     Order deny,allow  
  16.   
  17.     Deny from all  
  18.   
  19.   
  20.   
  21.    
  22.   
  23.   
  24.   
  25.     Options FollowSymLinks  
  26.   
  27.     AllowOverride All  
  28.   
  29.     Order deny,allow  
  30.   
  31.     Deny from all  
  32.   
  33.     Allow from 192.8  
  34.   
  35.   
  36.   
  37.    
  38.   
  39.   
  40.   
  41.     Options -Indexes FollowSymLinks  
  42.   
  43.     AllowOverride All  
  44.   
  45.     Order deny,allow  
  46.   
  47.     Deny from all  
  48.   
  49.     Allow from 192.8.102. 192.8.104. 192.8.22.  
  50.   
  51.   

 

设置完成后重启Apache服务生效。

安全是安全了,不过有一个问题,访问localhost下的页面会出现这样的情形:

 

 

其实我们再增加一句 Allow from127.0.0.1 ::1 localhost 即可解决此问题。如下:

 

[plain]  view plain  copy
 
 在CODE上查看代码片派生到我的代码片
  1.   
  2.   
  3.     Options -Indexes FollowSymLinks  
  4.   
  5.     AllowOverride All  
  6.   
  7.     Order deny,allow  
  8.   
  9.     Deny from all  
  10.   
  11.     Allow from 192.8.102. 192.8.104. 192.8.22.  
  12.   
  13.     Allow from 127.0.0.1 ::1 localhost  
  14.   
  15.   

 

重启再试,页面正常显示出来了。如下图:

 

现在搭建好了本地服务器,开启了若干监听端口,进入正题,接着说端口转发。

 

要使用端口转发(Port forwarding)功能,需要满足以下条件:

 

1.      在开发机器的Chrome浏览器打开chrome://inspect

2.      点击PortForwarding,弹出设置窗口

 

3.      在设备端口输入框,填写移动设备要监听的端口号(默认为8080)

4.      在Host主机输入域,填写运行web应用的当前ip地址(或主机名称,如localhost)加端口号。IP地址可以填写开发机器可访问的任何本地地址。当前,端口号范围必须在1024~65535之间(包括)

5.      选中Enableport forwarding.

6.      点击Done完成。

 

当chrome://inspect窗口的端口号闪动为绿色时,表明该端口转发配置已生效。此时你可以在移动设备上打开本地页面进行调试了。

在Chrome29之前端口转发功能有限,如果遇到问题,请确保你的Chrome版本升级到29以上再使用。在Chrome31+端口转发已经不是试验性功能了,而是正式发布的功能了。

 

前面我们已经搭建好本地服务器环境。接上USB线,打开chrome://inspect/#devices,根据Apache所设的监听端口,设置相应DevTools的端口转发参数,如下图:

 

 

 

完成了端口转发的设置后,这时候我们就可以进行调试本地环境下的页面了。

输入url,打开本地的页面。

例如

http://localhost:1818/taskmarket/index.html

http://localhost:8888/christmas/index.html

 

如下图所示:

 

 

 

虚拟主机映射(Virtual hostmapping)

 

当你在localhost域名(或你的本地开发机器IP)下调试,端口转发很灵验。不过,如果你要使用自己定制的本地域名来调试那就不管用了。

如果你在使用一个仅能运行于特定白名单中的域名下的JavascriptSDK,因此你在host文件中设置了如127.0.0.1 xxx.com这样的对应关系。或许你在Web服务器(MAMP,wamp,xampp等)用虚拟主机配置了个性的域名。

 

若是想让移动设备显示特定域名下页面内容,你需要使用上述的端口转发技术和代理服务器技术来实现。代理服务器可以将移动设备上的请求映射到主机的正确位置。

 

搭建代理

 

目前有许多搭建代理服务器的工具,比如Mac上的Charles Proxy,在Windows系统下的Fiddler,Linux下的Squid cache,Squid作为一款开源的代理服务软件,也可以用作Web缓存服务器,实现高速的Web访问需求。主机上安装运行代理服务器,所有来自安卓移动设备的请求都将会转发到代理服务器。

 

代理服务的搭建方法这里不细说看,感兴趣的可以参考我的文章或自行查找。

 

端口转发代理设置的步骤:

 

1.  安装代理服务软件,在主机上搭建代理服务器。

2.  开启代理服务,并确保代理服务器运行的端口与Chrome端口转发所设端口不相同。

3.  Chrome浏览器打开“检查设备”chrome://inspect

4.  点击Port forwarding 弹出设置窗口。

5.  设备端口处填上安卓设备要监听的端口,如9000。

6.  主机IP处可以填写localhost:xxxx,比如localhost:9000,也可以填写我上面配置过的本地域名a.test.com:1818

7.  勾选 Enableport forwarding

8.  点击Done按钮完成参数配置。

 

移动设备代理服务参数设置:

1.  打开设置-WLAN(Settings> Wi-Fi

2.  长按当前连接的无线网络(代理服务设置适用于每个无线网络)

3.  点击修改网络(Modify network

4.  勾选高级选项(Advanced options),将显示设置项:

 

 

5.  点击“代理”(Proxy)菜单选择“手动”(Manual

6.  在“代理服务器主机名”( Proxyhostname)处输入localhost或者127.0.0.1

7.  在“代理服务器端口”(Proxy port)处输入端口号,如9000

8.  点击保存(Save)。

通过以上参数设置,移动设备上所有请求被转发到主机的代理服务器,代理服务器代表安卓移动设备来发送请求,使得发送到特定域名下的请求得到了合理的解析。现在你可以调试特定域名下的页面了。

 

 


 

注意:为了不影响移动设备正常上网浏览,断开USB数据线后一定要恢复代理设置。

Fiddler默认使用8888端口,我的本地服务器已经占用8888端口,所以在Fiddler-Tools菜单中将监听端口设为未使用的10000端口,如图:

 

手机端代理设置参数完毕后,打开ChromeDevTools进行调试。点击inspect可以看到页面显示在手机浏览器了,现在开始调试吧。

我的测试页面为http://a.test.com:1818/taskmarket/index.html


 

DevTools实例的调试截图如下:

 

 

手机端Chrome for Android中的实时截图如下:

 

 

注意主机要和移动设备处在同一网段的局域网内。

移动端的调试还没有结束,下一节我会介绍Weinre远程调试的技巧和详细教程。

转载请注明出处:  freshlover的CSDN专栏文章《移动端Web开发调试之Chrome远程调试(Remote Debugging)》http://blog.csdn.NET/freshlover/article/details/42528643 


推荐阅读
  • 浏览器作为我们日常不可或缺的软件工具,其背后的运作机制却鲜为人知。本文将深入探讨浏览器内核及其版本的演变历程,帮助读者更好地理解这一关键技术组件,揭示其内部运作的奥秘。 ... [详细]
  • Spring – Bean Life Cycle
    Spring – Bean Life Cycle ... [详细]
  • 深入解析 Lifecycle 的实现原理
    本文将详细介绍 Android Jetpack 中 Lifecycle 组件的实现原理,帮助开发者更好地理解和使用 Lifecycle,避免常见的内存泄漏问题。 ... [详细]
  • 基于Web的Kafka管理工具Kafkamanager首次访问Web界面的详细配置指南(附图解)
    首次访问Kafkamanager Web界面时,需要对Kafka集群进行配置。这一过程相对简单,用户只需依次点击【Cluster】>【Add Cluster】,按照提示完成相关设置即可。本文将通过图文并茂的方式,详细介绍每一步的配置步骤,帮助用户快速上手Kafkamanager。 ... [详细]
  • 如何在Linux服务器上配置MySQL和Tomcat的开机自动启动
    在Linux服务器上部署Web项目时,通常需要确保MySQL和Tomcat服务能够随系统启动而自动运行。本文将详细介绍如何在Linux环境中配置MySQL和Tomcat的开机自启动,以确保服务的稳定性和可靠性。通过合理的配置,可以有效避免因服务未启动而导致的项目故障。 ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • 本文将带你快速了解 SpringMVC 框架的基本使用方法,通过实现一个简单的 Controller 并在浏览器中访问,展示 SpringMVC 的强大与简便。 ... [详细]
  • 解决 Windows Server 2016 网络连接问题
    本文详细介绍了如何解决 Windows Server 2016 在使用无线网络 (WLAN) 和有线网络 (以太网) 时遇到的连接问题。包括添加必要的功能和安装正确的驱动程序。 ... [详细]
  • 技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统
    技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统 ... [详细]
  • 在Linux系统中避免安装MySQL的简易指南
    在Linux系统中避免安装MySQL的简易指南 ... [详细]
  • Python错误重试让多少开发者头疼?高效解决方案出炉
    ### 优化后的摘要在处理 Python 开发中的错误重试问题时,许多开发者常常感到困扰。为了应对这一挑战,`tenacity` 库提供了一种高效的解决方案。首先,通过 `pip install tenacity` 安装该库。使用时,可以通过简单的规则配置重试策略。例如,可以设置多个重试条件,使用 `|`(或)和 `&`(与)操作符组合不同的参数,从而实现灵活的错误重试机制。此外,`tenacity` 还支持自定义等待时间、重试次数和异常处理,为开发者提供了强大的工具来提高代码的健壮性和可靠性。 ... [详细]
  • 卓盟科技:动态资源加载技术的兼容性优化与升级 | Android 开发者案例分享
    随着游戏内容日益复杂,资源加载过程已不仅仅是简单的进度显示,而是连接玩家与开发者的桥梁。玩家对快速加载的需求越来越高,这意味着开发者需要不断优化和提升动态资源加载技术的兼容性和性能。卓盟科技通过一系列的技术创新,不仅提高了加载速度,还确保了不同设备和系统的兼容性,为用户提供更加流畅的游戏体验。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 如何撰写适应变化的高效代码:策略与实践
    编写高质量且适应变化的代码是每位程序员的追求。优质代码的关键在于其可维护性和可扩展性。本文将从面向对象编程的角度出发,探讨实现这一目标的具体策略与实践方法,帮助开发者提升代码效率和灵活性。 ... [详细]
  • 深入对话上海视九叶文鑫:HTML5技术引领智能电视新趋势
    深入对话上海视九叶文鑫:HTML5技术引领智能电视新趋势 ... [详细]
author-avatar
qq7654ijh_416
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有