架构妄想:AJAX + REST

原文地址: http://www.infoq.com/cn/news/2011/10/ArchitecturalMirages

  William Vambenepe的最新文章,AJAX + REST是最新的架构妄想,让我们回想起了一个具有15年历史的架构,它曾被寄期望对Web产生革命性的影响。

在该架构里,Web服务器将返回包含全部数据的XML文件,与XML一道,还会返回一个XSLT文件(用于描述如何将XML转换成HTML)。浏览器将依此处理XML数据,显示最终的HTML。搞定!该方式将带来很多好处,优于老式的“服务器生成HTML”模型。XML可以被其他应用方便地使用(不仅仅是人类),不同的XSLT可被用来将内容适配到各种客户端平台。

  光阴飞逝,但这种理念其实从未真正实现。现在,我们又快速地转向Ajax:

XML文档还在,尽管它通常被称为JSON。XSLT现在则是一大堆JavaScript。比起XSLT模型,这种模型有许多优势……它更灵活,可以实现小规模更新,以及部分页面刷新等等。但是,它是否也能够让架构保持清晰,使数据API与表现逻辑相分离呢?

  Vambenepe解释了原因,尽管它看上去优雅并包含了所有的架构优点,但该模型在大多数情况下并不实际:

相同服务的客户端支持多种交互模型,若不无限制的蔓延开来,单个API很难满足所有这些模型的需要(这里,所谓“单一API”,其实就是一块遮羞布)。但若是想让API保持外观简洁,你最终可能就会得到交互频繁的应用。

  但是在Vambenepe看来,这仅仅是该方法诸多问题中的一个。他指出的另一个大问题是该方法的事实:

……摒弃集成了浏览器代码和服务器代码的架构……不是所有Web开发者都认为他们的客户端框架和服务器框架是两套工具。将它们整体作为一个预先装配好的工具使用或许不会得到最优的代码,但可能还是可以最优利用你的开发资源。

  尽管Vambenepe有强有力的论据,他的帖子还是遭到了质疑。什么才是正确之路?为现有UI(如GWT风格)创建/生成单独的REST API?一方面,这种方法简化了UI实现;另一方面,每个UI都要有一个新API。这种方法的伸缩性更好吗?哪个代价更高?实现UI集成,还是后端API?由这个帖子还产生了另一个更严肃的问题:什么是正确的设计方法?先实现后端API,然后设计多个使用它的UI;还是开始从UI开始设计,然后再定义支撑它的API?传统来看,API实现的代价似乎更高,但API本身要比UI更稳定。

  因此,没错,满足各种需求的单一API看起来是架构妄想。但是,一组设计良好、轻巧可重用的API可被用来作为许多UI(Ajax)实现的基础。

  查看英文原文:Architectural Mirages


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很好,我可以帮你编写一个简单的Python脚本来实现山海经跑图。 首先你需要导入两个Python库:PIL和pytesseract。PIL库用于图像处理,pytesseract库用于OCR识别文字。 接下来,你需要从图片中提取出文字。你可以使用PIL库中的Image模块打开图片,然后使用pytesseract库中的image_to_string函数将图片中的文字转换为字符串。 然后,你需要将山海经中的地名和路线提取出来。你可以使用Python的正则表达式来匹配这些字符串,并将它们保存到一个列表中。 最后,你可以使用Python的Web自动化库(如selenium)来模拟人工操作,让程序自动跑图。 以下是一个简单的Python脚本,用于提取山海经中的地名和路线,并自动跑图: ```python from PIL import Image import pytesseract import re from selenium import webdriver import time # 打开图片 img = Image.open('shanhaijing.jpg') # OCR识别图片中的文字 text = pytesseract.image_to_string(img, lang='chi_sim') # 提取地名和路线 place_pattern = re.compile(r'【(.*?)】') # 地名正则表达式 route_pattern = re.compile(r'→(.*?)\n') # 路线正则表达式 places = place_pattern.findall(text) routes = route_pattern.findall(text) # 打印地名和路线 for i in range(len(places)): print(f'{i + 1}、{places[i]}:{routes[i]}') # 自动跑图 driver = webdriver.Chrome() driver.get('https://shanhaimap.mihoyo.com/') # 点击开始游戏按钮 start_game_btn = driver.find_element_by_class_name('start-game') start_game_btn.click() # 等待动画播放完成 time.sleep(5) # 点击跑图按钮 run_btn = driver.find_element_by_class_name('run-btn') run_btn.click() # 依次点击地名和路线 for i in range(len(places)): time.sleep(1) place_btn = driver.find_element_by_xpath(f"//*[text()='{places[i]}']") place_btn.click() time.sleep(1) route_btn = driver.find_element_by_xpath(f"//*[text()='{routes[i]}']") route_btn.click() ``` 请注意,这只是一个简单的脚本,可能需要根据你的具体情况进行修改。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值