stale link..Exception

本文解决了Tapestry框架中StaleLink问题,通过为For组件所在的tr标签添加volatile=true属性,有效避免了大量数据加载时出现的StaleLink错误。
一个纠结许久的问题终于被解决!
Tapestry学习资料真难找,很多问题只有自己去悟,官方的文档还真是翻译不了,网上也是少之甚少.(也许是我没找着)...

来看看勒哥让人蛋疼的stale link...

(略写)页面代码:

<form name="Form0" jwcid="Form0@Form" listener="listener:forSubmit"
id="Form0">

<table xxxx>
<tr>
<th scope="col">xxxx</th>
<th scope="col">xxxx</th>
</tr>

<tr jwcid="@For" source="ognl:resultList" value="ognl:tempJO" element="tr">
<td>
<span>jwcid="@Insert"value="ognl:tempJO.tiaoma">xx</span>
</td>
<td>
<span>jwcid="@Insert"value="ognl:tempJO.tiaoma">xx</span>
</td>
<td>
<button type="button" jwcid="@Button">xxx</button>
</td>
</tr>
</table>
</form>


如上,代码是没什么问题,经过测试也成功.不过勒只是插上百来行数据,如果数据超过1000,或是更多,stale link 便出来勒。。在网上面找勒很多资料,似乎都没介绍如何处理这种情况的,我也是抱着试一试的心态,为For组件所在tr内 加勒一个属性: [color=red]volatile=“true”[/color].
重启服务器,http:localhost....
stale link消失。。。页面正常显示.
关于这个属性的具体内容,可以查看Tapestry4.1官方提供的组件API http://tapestry.apache.org/tapestry4.1/ 。本人英语水平有限,不能给出非常准确的翻译。这个我想等回家以后静下心来提高这篇文章的质量。到时候何大家分享!
FATAL EXCEPTION: main Process: com.tplink.vigi, PID: 3108 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.tplink.vigi/com.tplink.ipc.ui.deviceSetting.recordPlan.SettingRecordPlanSelectActivity}: android.view.InflateException: Binary XML file line #52 in com.tplink.vigi:layout/activity_setting_record_plan_select: Binary XML file line #52 in com.tplink.vigi:layout/activity_setting_record_plan_select: Error inflating class com.tplink.ipc.common.commonView.TPSecurTwoLineItemView at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3809) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3971) at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:103) at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2373) at android.os.Handler.dispatchMessage(Handler.java:106) at android.os.Looper.loopOnce(Looper.java:233) at android.os.Looper.loop(Looper.java:344) at android.app.ActivityThread.main(ActivityThread.java:8200) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:589) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1071) Caused by: android.view.InflateException: Binary XML file line #52 in com.tplink.vigi:layout/activity_setting_record_plan_select: Binary XML file line #52 in com.tplink.vigi:layout/activity_setting_record_plan_select: Error inflating class com.tplink.ipc.common.commonView.TPSecurTwoLineItemView Caused by: android.view.InflateException: Binary XML file line #52 in com.tplink.vigi:layout/activity_setting_record_plan_select: Error inflating class com.tplink.ipc.common.commonView.TPSecurTwoLineItemView Caused by: java.lang.reflect.InvocationTargetException at java.lang.reflect.Constructor.newInstance0(Native Method) at java.lang.reflect.Constructor.newInstance(Constructor.java:343) at android.view.LayoutInflater.createView(LayoutInflater.java:858) at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:1014) at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:965) at android.view.LayoutInflater.rInflate(LayoutInflater.java:1144) at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1105) at android.view.LayoutInflater.rInflate(LayoutInflater.java:1147) at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1105) at android.view.LayoutInflater.inflate(LayoutInflater.java:686) at android.view.LayoutInflater.inflate(LayoutInflater.java:538) at android.view.LayoutInflater.inflate(LayoutInflater.java:485) at androidx.appcompat.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:775) at androidx.appcompat.app.AppCompatActivity.setContentView(AppCompatActivity.java:197) at androidx.databinding.DataBindingUtil.setContentView(DataBindingUtil.java:303) at androidx.databinding.DataBindingUtil.setContentView(DataBindingUtil.java:284) at com.tplink.ipc.ui.deviceSetting.recordPlan.SettingRecordPlanSelectActivity.initView(SettingRecordPlanSelectActivity.kt:134) at com.tplink.ipc.ui.deviceSetting.recordPlan.SettingRecordPlanSelectActivity.onCreate(SettingRecordPlanSelectActivity.kt:89) at android.app.Activity.performCreate(Activity.java:8130) at android.app.Activity.performCreate(Activity.java:8110) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1343) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3778) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3971) at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:103) at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) 2025-07-31 13:50:40.650 3108-3108 AndroidRuntime com.tplink.vigi E at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2373) at android.os.Handler.dispatchMessage(Handler.java:106) at android.os.Looper.loopOnce(Looper.java:233) at android.os.Looper.loop(Looper.java:344) at android.app.ActivityThread.main(ActivityThread.java:8200) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:589) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1071) Caused by: java.lang.NullPointerException: Attempt to invoke interface method 'java.lang.Object kotlin.Lazy.getValue()' on a null object reference at com.tplink.design.list.TPTwoLineItemView.getItemViewHelper(TPListItemView.kt:618) at com.tplink.design.list.TPListItemView.setOnClickListener(TPListItemView.kt:376) at android.view.View.<init>(View.java:5840) at android.view.ViewGroup.<init>(ViewGroup.java:707) at androidx.constraintlayout.widget.ConstraintLayout.<init>(ConstraintLayout.java:598) at com.tplink.design.list.TPListItemView.<init>(TPListItemView.kt:54) at com.tplink.design.list.TPTwoLineItemView.<init>(TPListItemView.kt:614) at com.tplink.design.list.TPTwoLineItemView.<init>(TPListItemView.kt:609) at com.tplink.ipc.common.commonView.TPSecurTwoLineItemView.<init>(TPSecurTwoLineItemView.kt:13) ... 34 more
08-01
我运行上述代码出现了这个问题,实际上我是继承了自定义的BottomSheetDialogFragment,其中onCreateDialog已经返回了dialog,能不能设置返回的dailog无动画 2025-09-29 15:06:49.110 13314-13314 AndroidRuntime com.tplink.tpm5.trial E FATAL EXCEPTION: main Process: com.tplink.tpm5.trial, PID: 13314 java.lang.ClassCastException: android.graphics.drawable.ColorDrawable cannot be cast to com.google.android.material.shape.MaterialShapeDrawable at com.tplink.design.bottomsheet.TPModalBottomSheet.createMaterialShapeDrawable(TPModalBottomSheet.kt:787) at com.tplink.design.bottomsheet.TPModalBottomSheet.setBottomSheetShape(TPModalBottomSheet.kt:774) at com.tplink.design.bottomsheet.TPModalBottomSheet.initBottomSheetOperations$lambda$7(TPModalBottomSheet.kt:753) at com.tplink.design.bottomsheet.TPModalBottomSheet.$r8$lambda$Aj9FiF6GBfcm1Ce811-2dXUsXbI(Unknown Source:0) at com.tplink.design.bottomsheet.TPModalBottomSheet$$ExternalSyntheticLambda1.run(Unknown Source:4) at android.os.Handler.handleCallback(Handler.java:966) at android.os.Handler.dispatchMessage(Handler.java:110) at android.os.Looper.loopOnce(Looper.java:205) at android.os.Looper.loop(Looper.java:293) at android.app.ActivityThread.loopProcess(ActivityThread.java:10173) at android.app.ActivityThread.main(ActivityThread.java:10162) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:593) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1247)
09-30
C:\Users\admin>curl -k -v -b cookies.txt -X PROPFIND -H "Depth: 1" "https://fileshare-cd.tp-link.com/remote.php/dav/files/husiyu@tp-link.com.hk/" * Host fileshare-cd.tp-link.com:443 was resolved. * IPv6: (none) * IPv4: 10.13.136.24 * Trying 10.13.136.24:443... * schannel: disabled automatic use of client certificate * ALPN: curl offers http/1.1 * ALPN: server accepted http/1.1 * Connected to fileshare-cd.tp-link.com (10.13.136.24) port 443 * using HTTP/1.x > PROPFIND /remote.php/dav/files/husiyu@tp-link.com.hk/ HTTP/1.1 > Host: fileshare-cd.tp-link.com > User-Agent: curl/8.10.1 > Accept: */* > Cookie: __Host-nc_sameSiteCookiestrict=true; __Host-nc_sameSiteCookielax=true; oc_sessionPassphrase=8efm%2B84zGiNK95DvPaSwVdwEI7B86sscqGQGnWK4fPTTIEAdDI3QQ5EXFH%2FTbt7Lx%2FoyiadUEH8YryOnIbZNumTRzY5hFQrZyagIcd61Hic%2FY1ou9DApu7ElGQ%2F%2BN5S1; ocas9uhx9acd=grdcvu9hfjd1io8512tf4aru72 > Depth: 1 > * Request completely sent off < HTTP/1.1 401 Unauthorized < Date: Tue, 02 Dec 2025 06:50:23 GMT < Server: Apache/2.4.58 (Ubuntu) < Strict-Transport-Security: max-age=15768000; includeSubDomains < Referrer-Policy: no-referrer < X-Content-Type-Options: nosniff < X-Frame-Options: SAMEORIGIN < X-Permitted-Cross-Domain-Policies: none < X-Robots-Tag: noindex, nofollow < X-XSS-Protection: 1; mode=block < Upgrade: h2,h2c < Connection: Upgrade < Content-Security-Policy: default-src 'none';base-uri 'none';manifest-src 'self';script-src 'self';style-src 'self' 'unsafe-inline';img-src 'self' data: blob:;font-src 'self' data:;connect-src 'self';media-src 'self';frame-ancestors 'self';form-action 'self' * Replaced cookie ocas9uhx9acd="grdcvu9hfjd1io8512tf4aru72" for domain fileshare-cd.tp-link.com, path /, expire 0 < Set-Cookie: ocas9uhx9acd=grdcvu9hfjd1io8512tf4aru72; path=/; secure; HttpOnly; SameSite=Lax < WWW-Authenticate: Basic realm="fileshare", charset="UTF-8" < Content-Length: 527 < Content-Type: application/xml; charset=utf-8 < <?xml version="1.0" encoding="utf-8"?> <d:error xmlns:d="DAV:" xmlns:s="http://sabredav.org/ns"> <s:exception>服务器内部错误</s:exception> <s:message> 服务器不能完成您的请求。 如果再次发生这种情况,请将下面的技术详细信息发送给服务器管理员。更多细节可以在服务器日志中找到。 </s:message> <s:technical-details> <s:remote-address>10.13.34.170</s:remote-address> <s:request-id>qhcGu23hjgPDZQ84eCF3</s:request-id> </s:technical-details> </d:error> * Connection #0 to host fileshare-cd.tp-link.com left intact
最新发布
12-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值