当前位置: 首页 > news >正文

目前网站开发语言ios网站开发视频教程

目前网站开发语言,ios网站开发视频教程,网站怎么做用什么软件,图片seo优化是什么意思本文介绍了一个Nextcloud内嵌网页插件webviewwidget的开发过程。该插件允许在Dashboard中添加iframe网页视图,主要解决了CSP策略拦截问题。通过自定义ContentSecurityPolicy类添加addAllowedFrameDomain(‘*’)来允许任意域名嵌入,并提供了完整的目录结构…

本文介绍了一个Nextcloud内嵌网页插件webviewwidget的开发过程。该插件允许在Dashboard中添加iframe网页视图,主要解决了CSP策略拦截问题。通过自定义ContentSecurityPolicy类添加addAllowedFrameDomain(‘*’)来允许任意域名嵌入,并提供了完整的目录结构和关键代码示例,包括控制器设置、路由配置和模板文件。最终实现了在Nextcloud 31.0.5.1版本中安全嵌入外部网页的功能。

services:nextcloud:image: nextcloudenvironment:- PHP_OPCACHE_MEMORY_CONSUMPTION=256volumes:- ./nextcloud_html:/var/www/htmlports:- "80:80"

在这里插入图片描述

nextcould版本 ‘version’ => ‘31.0.5.1’,

#清缓存
$ php occ maintenance:repair --include-expensive
├── appinfo
│   ├── info.xml
│   └── routes.php
├── css
│   └── webview.css
├── img
│   └── net.svg
├── lib
│   └── Controller
│       └── WebViewController.php
└── templates└── main.php

appinfo/info.xml

<?xml version="1.0"?>
<info xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance"xsi:noNamespaceSchemaLocation="https://apps.nextcloud.com/schema/apps/info.xsd"><id>webviewwidget</id><name>内嵌网页</name><summary>在 Dashboard 里放 iframe</summary><description><![CDATA[最小可运行 demo:Dashboard webviewWidget。启用后,用户可在「自定义」里添加「内嵌网页」模块。]]></description><version>1.0.0</version><licence>agpl</licence><author>NC Demo</author><namespace>WebviewWidget</namespace><category>dashboard</category><dependencies><nextcloud min-version="31" max-version="31"/></dependencies><navigations><navigation><id>webview</id><name>内嵌网页</name><route>webviewwidget.webview.view</route><icon>/custom_apps/webviewwidget/img/net.svg</icon><order>80</order>   <!-- 数字越大越靠后 --><type>link</type></navigation>
</navigations>
</info>

appinfo/routes.php

<?php
return ['routes' => [['name' => 'webview#view', 'url' => '/webview', 'verb' => 'GET']]
];

css/webview.css

#app {width: 100%;height: calc(100vh - 50px); /* 去掉顶部栏高度 */
}
#app iframe {width: 100%;height: 100%;
}

svg图标,去网上找一个

  • Nextcloud 只接受 SVG 矢量图 作为顶部导航图标,
    .ico、.png、.jpg 都会被忽略或显示成 空白/破图

解决 CSP 拦截(重点)

webview:129 Refused to frame 'https://example.com/ ’ because it violates the following Content Security Policy directive: “frame-src ‘self’”.

异常响应头
frame-src ‘self’; 事件监听 仍然没生效,NC 31 还是走的默认 CSP。

Content-Security-Policy: default-src 'none';base-uri 'none';manifest-src 'self';script-src 'nonce-/OLkPjlThFuh8Qj5XvikJdztIGop05wYfsXxNIBJox0=';script-src-elem 'strict-dynamic' 'nonce-/OLkPjlThFuh8Qj5XvikJdztIGop05wYfsXxNIBJox0=';style-src 'self' 'unsafe-inline';img-src 'self' data: blob: https://*.tile.openstreetmap.org;font-src 'self' data:;connect-src 'self';media-src 'self';frame-src 'self';frame-ancestors 'self';form-action 'self'

增加如下控制器
lib/Controller/WebViewController.php

<?php
declare(strict_types=1);
namespace OCA\WebviewWidget\Controller;use OCP\AppFramework\Controller;
use OCP\AppFramework\Http\TemplateResponse;
use OCP\IRequest;class WebViewController extends Controller {public function __construct(IRequest $request) {parent::__construct('webviewwidget', $request);}/*** @NoAdminRequired* @NoCSRFRequired*/public function view(): TemplateResponse {$response = new TemplateResponse('webviewwidget', 'main');// 关键:覆盖默认 CSP$csp = new \OCP\AppFramework\Http\ContentSecurityPolicy();$csp->addAllowedFrameDomain('*');$response->setContentSecurityPolicy($csp);return $response;}
}

能正常访问的响应头

Content-Security-Policy: default-src 'none';base-uri 'none';manifest-src 'self';script-src 'nonce-cdPOruzwkSjGokPijyoieLdf495o2gVQ2yRBkrDRuNU=';script-src-elem 'strict-dynamic' 'nonce-cdPOruzwkSjGokPijyoieLdf495o2gVQ2yRBkrDRuNU=';style-src 'self' 'unsafe-inline';img-src 'self' data: blob: https://*.tile.openstreetmap.org;font-src 'self' data:;connect-src 'self';media-src 'self';frame-src 'self' *;frame-ancestors 'self';form-action 'self'

templates/main.php

<?php
style('webviewwidget', 'webview');
?><div id="app"><iframe src="https://www.baidu.com"width="100%" height="100%"frameborder="0"sandbox="allow-same-origin allow-scripts allow-popups allow-forms"></iframe>
</div>

进入容器, 执行启动

php occ app:enable webviewwidget
webviewwidget:1.0.0

php occ app:disable webviewwidget

最终效果
在这里插入图片描述

http://www.dtcms.com/a/454953.html

相关文章:

  • 室内设计8年熬不起了兰州企业网络优化方案
  • 网站建设做的好网站设计色板
  • PySide6 自定义文本查找对话框(QFindTextDialog)以及调用示例
  • 做网站公司报价惠州做棋牌网站建设有哪些公司
  • 苏州交通网站建设中国百强企业
  • 响应式网站预览福建建设网站
  • wordpress 网站标题设置免费网站一级a做爰在免费线看
  • 教学设计代做去什么网站产品宣传推广方案
  • MySQL主主复制+Keepalived高可用配置
  • 网站的留言板怎么做网站防封链接怎么做
  • 郓城做网站公司西宁平台网站建设
  • 去马来西亚做网站网站网站后台模块
  • spring容器启动流程(反射视角)
  • 佛山 网站关键词优化链接怎么做
  • SSM--day3--Spring(三)--AOP事务(补漏)
  • 石家庄招聘哪个网站做的好暴雪国服回归
  • 国外域名 网站备案微信网页版下载
  • 多线程案例四
  • 网站建设 网站制作外贸网站
  • 可以进不良网站的浏览器做关键词排名好的公司
  • 网站升级中安徽安庆邮编
  • 国家免费编程平台上海市网站seo公司
  • 从“图书馆借书”到mmap:内存映射的魔法
  • 网站主机的选择与优化网站个人和企业有什么区别
  • 云集网站建设公司网站建设适合的企业
  • 显示网站建设精美页面wordpress wap
  • 做网站有什么类型打开网站iis7
  • 网站设计想法成都旅游线路
  • 中济建设官方网站有没有专业做艺术品的网站
  • AssemblyScript 入门教程(8):控制台日志与调试