用powershell开发跨平台动态网页

powershell 动态 网页 跨平台 asp.net dynamic cross platform

powershell 传教士 原创文章。始于 2023-04-03 允许转载,但必须保留名字和出处

---【前言】---

以【vbs,和微软jsript】为核心的asp已经淘汰了。ie11后来都不支持网页内嵌vbs了。
asp前后端不分离,jscript非正宗javascript标准,导致兼容性不佳。又没有大厂支持,连微软都不支持了。
asp可以被理解为【瘸腿的沙发,废弃的破烂,没元件件可更换的坏相机】

 

从.net跨平台那天起,asp.net就能开发跨平台动态网页。在asp.net中执行powershell代码也是早就有的,但那需要写c#代码。
在微软眼中,用c#写asp.net永远是正宫。他们不会主流去支持【用ps做动态网页开发语言】。
但我们玩powershell的是想以ps为主。我们不会用,也不想用c#去开发网站后台。

看到python家开发动态网站,我是有些羡慕嫉妒恨的。不过这种情况结束了。近期和外国同行讨论,一起研究出了示例代码。p老爷的这条瘸腿被接上了!!!

 

本例将为您展示:
1 在win,linux版powershell v7.3中,用powershell加载win,linux版asp.net库。
2 用powershell动态返回一个值,交给前端javascript去美化,去渲染页面。
------ 用纯powershell脚本&代码作为网页动态语言的例子。

---【图例:全部脚本代码,和相关库】---

 用powershell开发跨平台动态网页

 

https://gitee.com/chuanjiao10/kasini3000web

在win中运行服务器,并使用chrome浏览器测试通过。
在linux中运行服务器,并使用curl测试通过。

---【正文】---

 

使用场景:
* 运维,管理员用的中小型网站,dashboard。
* 按某按钮后,用powershell代码,加win语音库,朗读中英文文字,单词。
* 展示表格。
* 输入某些值,并用后台powershell,调用数据库客户端,把刚才的数据,写入单机库sqlite,litedb,excel文件,mysql库,sqlserver,etcd库等。
* powershell调用公有云命令行,私有云命令行,建立删除云虚拟机。网络。
* powershell调用ad,exchange,管理账户,邮箱,dns等。

案例:
目前我用它开发kasini3000的web框架。
框架还没开始,目前只是简陋的例子,勿喷。

系统需求:
powershell v7.3.x。
目前暂时只支持这个版本,因为asp.net类库我目前下载的都是.net7版本的。
未来绝对会升级到.net8的,届时需要使用powershell v7.4.x,以便ps版本和.net类库版本一致。

 

------------------【开始讲解例子】------------------

 

1 制作首页。首页上有个web form,上面有个post方法的按钮。html代码:

<form action="/getdate/" method="post">
<input type="submit" name="Logon" value="按此" />

 

2 首页,powershell代码:

$主页代码 = {
    param($HttpContext,$pagefile2)
    $pindex = Get-Content -Path $pagefile2 -Raw
    $a = [System.Text.Encoding]::UTF8.GetBytes($pindex)
    $HttpContext.Response.Body.WriteAsync($a, 0, $a.Length).AsTask().Wait()
}
$主页委托 = [powerShellDelegate]::new($主页代码,'index.html')

 

 

3 get-date命令,powershell代码:

$获取时间代码 = {
    param($HttpContext)
    $d = Get-Date -Format F
    $a = [System.Text.Encoding]::GetEncoding(936).GetBytes($d)
    $HttpContext.Response.Body.WriteAsync($a, 0, $a.Length).AsTask().Wait()
}
$获取时间委托 = [powerShellDelegate]::new($获取时间代码,'')

 

4 把首页添加到路由。把get-date命令,添加到路由【/getdate】。
注意:首页是get方法,get-date是post方法。powershell代码:

[Void][Microsoft.AspNetCore.Builder.EndpointRoutingApplicationBuilderExtensions]::UseEndpoints($App, { [Microsoft.AspNetCore.Builder.EndpointRouteBuilderExtensions]::MapGet($args[0],"/", $主页委托.Invoke) })
[Void][Microsoft.AspNetCore.Builder.EndpointRoutingApplicationBuilderExtensions]::UseEndpoints($App, { [Microsoft.AspNetCore.Builder.EndpointRouteBuilderExtensions]::MapPost($args[0],"/getdate/", $获取时间委托.Invoke) })

 

---【后记】---

当然,你还可以这样: 写一个d:\xxx\a.ps1作为回调脚本。
当每次访问http://127.0.0.1:5000/a 时, 执行此脚本。

我脑子中只有一件事:替“潘而少”老爷把,【网页动态语言】这条瘸腿接上。

-完-

原文链接:https://www.cnblogs.com/piapia/p/17293828.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:用powershell开发跨平台动态网页 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • 浅谈C#中[]的几种用法

    浅谈C#中[]的几种用法 在C#中,方括号[]有着多种不同的用法。本文将全面解析它们的用法及细节。 数组 最经典的用法就是定义数组。数组是将相同类型的变量按一定顺序排列组合而成的一组数据,它们共用一个名称。使用时可以通过索引(下标)来访问这些变量。先看下面的示例代码: int[] scores = { 12, 34, 56, 78, 99 }; Consol…

    C# 2023年6月1日
    00
  • C#算法之大牛生小牛的问题高效解决方法

    C#算法之大牛生小牛的问题高效解决方法 问题描述 题目来源于 LeetCode,现在有一只大牛和一只小牛,它们的初始体重分别为 $x$ 和 $y$,每年它们的体重都会增加固定的比例(比例为 $p$),求当小牛的体重超过大牛的体重时,需要多少年。 解题思路 考虑使用循环解决。 每年大牛的体重增加 $p$%,小牛的体重增加 $2p$%,那么循环条件可以设为小牛体…

    C# 2023年6月7日
    00
  • C#开发之Socket网络编程TCP/IP层次模型、端口及报文等探讨

    C#开发之Socket网络编程TCP/IP层次模型、端口及报文等探讨 简介 本文主要介绍使用C#进行Socket网络编程时,涉及到的TCP/IP协议中的各个层次模型、端口以及报文等内容,并提供两个基本示例进行说明。 TCP/IP协议层次模型 TCP/IP协议是网络通信的基础,它将网络通信分为许多层,每一层负责不同的任务。这些层从下往上分别是:物理层、数据链路…

    C# 2023年6月7日
    00
  • 跳一跳自动跳跃C#代码实现

    下面我会为你详细讲解“跳一跳自动跳跃C#代码实现”的完整攻略。 背景知识 跳一跳是一款非常受欢迎的休闲游戏,它的玩法是通过跳跃规避障碍物,每跳一次就得一分。在游戏中,如果你跳的不够准确,就会掉到河里,游戏就结束了。为了让用户的游戏体验更好,我们可以通过编写一个自动跳跃的程序,帮助用户自动跳跃,获得更高的分数。 实现过程 1. 获取游戏屏幕截图 首先,我们需要…

    C# 2023年6月6日
    00
  • ASP.NET中的URL过滤实现代码

    关于ASP.NET中的URL过滤实现代码,可以分为以下几个步骤: 1. 在Web.config中配置URL过滤规则 在ASP.NET中,可以使用系统自带的UrlRoutingModule类进行Url处理,可以在Web.config文件中配置一个HTTP模块将HTTP请求映射到这个类上。 代码如下所示: <system.webServer> &lt…

    C# 2023年5月31日
    00
  • 在C#中使用SQLite数据库

    轻量级桌面程序数据库不太适合用SQLServer、MySQL之类的重量级数据库,嵌入式数据库更好。在对比Access、SQLite、Firebird数据库后发现SQLite较另外两个有较多优点。 环境:.NET Framework 3.5、windows11 64位、Visual Studio 2010. C#使用SQLite需要从SQLite官网下载DLL…

    C# 2023年4月27日
    00
  • C# 中 System.Index 结构体和 Hat 运算符(^)的使用示例

    C# 中 System.Index 结构体和 Hat 运算符(^) 的使用是一项比较新的功能,适用于 C# 8.0 及以上版本,主要用于对序列和数组的索引操作,下面就来详细讲解一下它的使用。 System.Index 结构体 System.Index 结构体是 C# 8.0 添加的一个新类型,它允许我们以更简洁而直观的方式进行索引操作。例如,我们可以使用它来…

    C# 2023年6月7日
    00
  • .NET2.0版本中基于事件的异步编程模式(EAP)

    . 简介: 基于事件的异步编程模式(EAP)是.NET Framework 2.0 中引入的一种编程模式,是一种异步编程的方式,与.NET中的APM(异步编程模型)和TPL(任务并行库)不同,入口点不是Beginxxx和Endxxx方法或Task的异步方法,而是定义了异步方法并触发事件来通知异步操作完成。异步执行单元采用回调函数注册的方式,通过在异步操作完成…

    C# 2023年6月6日
    00
合作推广
合作推广
分享本页
返回顶部