修改浏览器使之支持WML格式页面(1)

?

1
2
3
4
5
6
7
bool DOMImplementation::isXMLMIMEType( const String& mimeType) {
     if (mimeType == "text/xml" || mimeType == "application/xml" || mimeType == "text/xsl" )
         return true ;
     static const char * const validChars = "[0-9a-zA-Z_\\-+~!$\\^{}|.%'`#&*]" ; // per RFCs: 3023, 2045
     DEFINE_STATIC_LOCAL(RegularExpression, xmlTypeRegExp, (String( "^" ) + validChars + "+/" + validChars + "+\\+xml$" , TextCaseSensitive));
     return xmlTypeRegExp.match(mimeType) > - 1 ;
}

这里只包含了text/xml, application/xml, text/xls. 我们需要把WML相应的MiMeType类型加进去

?

1
If(mimeType == “text/vnd.wap.wml”) return true ;

修改framework/base/core/java/android/webkit/LoadListener.java, 源码如下:

?

1
2
3
4
5
6
7
8
9
// Does the header parsing work on the WebCore thread.
private void handleHeaders(Headers headers) {
    
}
else if (mMimeType.equals( "text/vnd.wap.wml" )) {
     // As we don't support wml, render it as plain text
     mMimeType = "text/plain" ;
  
}

我们可以看到, 原来是不支持wml格式的, 都当做text/plain来处理了,这样显然是不能正确显示的。 所以这一行mMimeType = “text/plain”;需要注释掉,打开给外围。

2. 对WML中的超链接元素(WMLAElement和WMLAnchorElement)中href属性值里面的变量替换。

笔者发现,在一个WML的登陆页面上,填入用户名和密码后,点击登陆,附加到url后面的用户名和密码是 ( u s e r n a m e ) 和 (username) 和 (username)(password) ,有web开发经验的XDJM都知道,这是没有将变量替换为页面上相应值。我们看WMLAElement.cpp中处理点击事件的方法:

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
void WMLAElement::defaultEventHandler(Event* event) {
     if (isLink() && (event->type() == eventNames().clickEvent || (event->type() == eventNames().keydownEvent && focused()))) {
         MouseEvent* e = 0 ;
         if (event->type() == eventNames().clickEvent && event->isMouseEvent())
             e = static_cast<MouseEvent*>(event);
  
         KeyboardEvent* k = 0 ;
         if (event->type() == eventNames().keydownEvent && event->isKeyboardEvent())
             k = static_cast<KeyboardEvent*>(event);
  
         if (e && e->button() == RightButton) {
             WMLElement::defaultEventHandler(event);
             return ;
         }
  
         if (k) {
             if (k->keyIdentifier() != "Enter" ) {
                 WMLElement::defaultEventHandler(event);
                 return ;
             }
  
             event->setDefaultHandled();
             dispatchSimulatedClick(event);
             return ;
         }
  
         if (!event->defaultPrevented() && document()->frame()) {
             String url = document()->completeURL(deprecatedParseURL(getAttribute(HTMLNames::hrefAttr)));
             /
             document()->frame()->loader()->urlSelected(url, target(), event, false , false , true , SendReferrer);
         }
  
         event->setDefaultHandled();
     }
}

通过打印Log发现,getAttribute(HTMLNames::hrefAttr)获取的只是href后面的字符串,包含变量$(). 我们需要对其中的变量进行转化。还好WMLVariables里面已经提供了相应的方法substituteVariableReferences,不需要我们再去写一个了。修改如下

#include “WMLVariables.h”

?

1
2
3
4
5
6
if (!event->defaultPrevented() && document()->frame()) {
     // Substitute variables within target url attribute value. String href = getAttribute(HTMLNames::hrefAttr);
     href = substituteVariableReferences(href, document(), WMLVariableEscapingEscape);
     String url = document()->completeURL(deprecatedParseURL(href));
     document()->frame()->loader()->urlSelected(url, target(), event, false , false , true , SendReferrer);
}

别忘了,WMLAnchorElement.cpp中相应的地方也要同样改掉。

3. 在页面上长按链接时弹出选项点击失效

这是由于点击时是从webkit层去获取这个链接的地址和标题的, 而源码中只考虑了HTML格式的页面, WML页面被忽略了。 返回的href为null.

首先要在WMLAElement.cpp中提供接口, 返回链接。

?

1
2
3
4
5
6
KURL WMLAElement::href() const {
     // Substitute variables within target url attribute value.
     String href = substituteVariableReferences(getAttribute(HTMLNames::hrefAttr),
     document(), WMLVariableEscapingEscape);
     return document()->completeURL(href);
}

由于WMLAnchorElement继承了WMLAElement, 就不需要再添加这个方法了。

然后修改WebViewCore.cpp, 原来获取href的方法是这样的:

?

1
2
3
4
WebCore::String WebViewCore::retrieveHref(WebCore::Frame* frame, WebCore::Node* node) {
     WebCore::HTMLAnchorElement* anchor = retrieveAnchorElement(frame, node);
     return anchor ? anchor->href() : WebCore::String();
}

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

文末

那么对于想坚持程序员这行的真的就一点希望都没有吗?
其实不然,在互联网的大浪淘沙之下,留下的永远是最优秀的,我们考虑的不是哪个行业差哪个行业难,就逃避掉这些,无论哪个行业,都会有他的问题,但是无论哪个行业都会有站在最顶端的那群人。我们要做的就是努力提升自己,让自己站在最顶端,学历不够那就去读,知识不够那就去学。人之所以为人,不就是有解决问题的能力吗?挡住自己的由于只有自己。
Android希望=技能+面试

  • 技能
  • 面试技巧+面试题
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

试题**
[外链图片转存中…(img-u5siFEev-1711940461341)]

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值