WPF 实现抽屉菜单

 分享一个WPF 实现抽屉菜单

抽屉菜单

作者:WPFDevelopersOrg

原文链接:https://github.com/WPFDevelopersOrg/WPFDevelopers

  • 框架使用大于等于.NET40

  • Visual Studio 2022;

  • 项目使用 MIT 开源许可协议;

  • 更多效果可以通过GitHub[1]|码云[2]下载代码;

  • 由于在WPF中没有现成的类似UWP的抽屉菜单,所以我们自己实现一个。

1) DrawerMenu.cs 代码如下。

using System.Collections.Generic;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Media;namespace WPFDevelopers.Controls
{public class DrawerMenu : ContentControl{public new static readonly DependencyProperty ContentProperty =DependencyProperty.Register("Content", typeof(List<DrawerMenuItem>), typeof(DrawerMenu),new FrameworkPropertyMetadata(null));public static readonly DependencyProperty IsOpenProperty =DependencyProperty.Register("IsOpen", typeof(bool), typeof(DrawerMenu), new PropertyMetadata(true));public static readonly DependencyProperty MenuIconColorProperty =DependencyProperty.Register("MenuIconColor", typeof(Brush), typeof(DrawerMenu),new PropertyMetadata(Brushes.White));public static readonly DependencyProperty SelectionIndicatorColorProperty =DependencyProperty.Register("SelectionIndicatorColor", typeof(Brush), typeof(DrawerMenu),new PropertyMetadata(DrawingContextHelper.Brush));public static readonly DependencyProperty MenuItemForegroundProperty =DependencyProperty.Register("MenuItemForeground", typeof(Brush), typeof(DrawerMenu),new PropertyMetadata(Brushes.Transparent));static DrawerMenu(){DefaultStyleKeyProperty.OverrideMetadata(typeof(DrawerMenu),new FrameworkPropertyMetadata(typeof(DrawerMenu)));}public new List<DrawerMenuItem> Content{get => (List<DrawerMenuItem>)GetValue(ContentProperty);set => SetValue(ContentProperty, value);}public bool IsOpen{get => (bool)GetValue(IsOpenProperty);set => SetValue(IsOpenProperty, value);}public Brush MenuIconColor{get => (Brush)GetValue(MenuIconColorProperty);set => SetValue(MenuIconColorProperty, value);}public Brush SelectionIndicatorColor{get => (Brush)GetValue(SelectionIndicatorColorProperty);set => SetValue(SelectionIndicatorColorProperty, value);}public Brush MenuItemForeground{get => (Brush)GetValue(MenuItemForegroundProperty);set => SetValue(MenuItemForegroundProperty, value);}public override void BeginInit(){Content = new List<DrawerMenuItem>();base.BeginInit();}}
}

2) DrawerMenuItem.cs 代码如下。

using System.Windows;
using System.Windows.Controls;
using System.Windows.Input;
using System.Windows.Media;namespace WPFDevelopers.Controls
{public class DrawerMenuItem : ListBoxItem{public static readonly DependencyProperty TextProperty =DependencyProperty.Register("Text", typeof(string), typeof(DrawerMenuItem),new PropertyMetadata(string.Empty));public static readonly DependencyProperty IconProperty =DependencyProperty.Register("Icon", typeof(ImageSource), typeof(DrawerMenuItem),new PropertyMetadata(null));public static readonly DependencyProperty SelectionIndicatorColorProperty =DependencyProperty.Register("SelectionIndicatorColor", typeof(Brush), typeof(DrawerMenuItem),new PropertyMetadata(DrawingContextHelper.Brush));public static readonly DependencyProperty SelectionCommandProperty =DependencyProperty.Register("SelectionCommand", typeof(ICommand), typeof(DrawerMenuItem),new PropertyMetadata(null));static DrawerMenuItem(){DefaultStyleKeyProperty.OverrideMetadata(typeof(DrawerMenuItem),new FrameworkPropertyMetadata(typeof(DrawerMenuItem)));}public string Text{get => (string)GetValue(TextProperty);set => SetValue(TextProperty, value);}public ImageSource Icon{get => (ImageSource)GetValue(IconProperty);set => SetValue(IconProperty, value);}public Brush SelectionIndicatorColor{get => (Brush)GetValue(SelectionIndicatorColorProperty);set => SetValue(SelectionIndicatorColorProperty, value);}public ICommand SelectionCommand{get => (ICommand)GetValue(SelectionCommandProperty);set => SetValue(SelectionCommandProperty, value);}}
}

3) DrawerMenu.xaml 代码如下。

<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:po="http://schemas.microsoft.com/winfx/2006/xaml/presentation/options"xmlns:controls="clr-namespace:WPFDevelopers.Controls"><ResourceDictionary.MergedDictionaries><ResourceDictionary Source="Basic/ControlBasic.xaml"/></ResourceDictionary.MergedDictionaries><Style x:Key="DrawerMenuToggleButton" TargetType="ToggleButton" BasedOn="{StaticResource ControlBasicStyle}"><Setter Property="IsChecked" Value="False"/><Setter Property="Template"><Setter.Value><ControlTemplate TargetType="{x:Type ToggleButton}"><Grid Background="{TemplateBinding Background}"><ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" /></Grid></ControlTemplate></Setter.Value></Setter><Style.Triggers><Trigger Property="IsMouseOver" Value="True"><Setter Property="Opacity" Value="0.8" /><Setter Property="Cursor" Value="Hand" /><Setter Property="Template"><Setter.Value><ControlTemplate TargetType="{x:Type ToggleButton}"><BorderBackground="{TemplateBinding Background}"BorderBrush="Black"BorderThickness="1"><ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" /></Border></ControlTemplate></Setter.Value></Setter></Trigger></Style.Triggers></Style><Style x:Key="DrawerMenuListBox" TargetType="ListBox" BasedOn="{StaticResource ControlBasicStyle}"><Setter Property="Background" Value="Transparent" /><Setter Property="BorderBrush" Value="Transparent" /><Setter Property="BorderThickness" Value="0"/><Setter Property="Template"><Setter.Value><ControlTemplate><ScrollViewer><ItemsPresenter Margin="0" /></ScrollViewer></ControlTemplate></Setter.Value></Setter></Style><Style x:Key="ButtonFocusVisual"><Setter Property="Control.Template"><Setter.Value><ControlTemplate><Border><Rectangle Margin="2"StrokeThickness="1"Stroke="#60000000"StrokeDashArray="1 2"/></Border></ControlTemplate></Setter.Value></Setter></Style><!-- Fill Brushes --><SolidColorBrush x:Key="NormalBrush" Color="Transparent"  po:Freeze="True"/><SolidColorBrush x:Key="DarkBrush" Color="#ddd"  po:Freeze="True"/><SolidColorBrush x:Key="PressedBrush" Color="#80FFFFFF"  po:Freeze="True"/><SolidColorBrush x:Key="DisabledForegroundBrush" Color="Transparent"  po:Freeze="True"/><SolidColorBrush x:Key="DisabledBackgroundBrush" Color="Transparent"  po:Freeze="True"/><!-- Border Brushes --><SolidColorBrush x:Key="NormalBorderBrush" Color="Transparent"  po:Freeze="True"/><SolidColorBrush x:Key="PressedBorderBrush" Color="Transparent"  po:Freeze="True"/><SolidColorBrush x:Key="DefaultedBorderBrush" Color="Transparent"  po:Freeze="True"/><SolidColorBrush x:Key="DisabledBorderBrush" Color="Transparent"  po:Freeze="True"/><Style x:Key="DrawerMenuItemButtonStyle" TargetType="Button" BasedOn="{StaticResource ControlBasicStyle}"><Setter Property="FocusVisualStyle" Value="{StaticResource ButtonFocusVisual}"/><Setter Property="MinHeight" Value="23"/><Setter Property="MinWidth" Value="75"/><Setter Property="Cursor" Value="Hand" /><Setter Property="Template"><Setter.Value><ControlTemplate TargetType="Button"><Border x:Name="Border"  CornerRadius="0" BorderThickness="0"Background="Transparent"BorderBrush="Transparent"><ContentPresenter HorizontalAlignment="Stretch"VerticalAlignment="Stretch"RecognizesAccessKey="True"/></Border><ControlTemplate.Triggers><Trigger Property="IsKeyboardFocused" Value="true"><Setter TargetName="Border" Property="BorderBrush" Value="{DynamicResource DefaultedBorderBrush}" /></Trigger><Trigger Property="IsDefaulted" Value="true"><Setter TargetName="Border" Property="BorderBrush" Value="{DynamicResource DefaultedBorderBrush}" /></Trigger><Trigger Property="IsMouseOver" Value="true"><Setter TargetName="Border" Property="Background" Value="{DynamicResource DarkBrush}" /></Trigger><Trigger Property="IsPressed" Value="true"><Setter TargetName="Border" Property="Background" Value="{DynamicResource PressedBrush}" /><Setter TargetName="Border" Property="BorderBrush" Value="{DynamicResource PressedBorderBrush}" /></Trigger><Trigger Property="IsEnabled" Value="false"><Setter TargetName="Border" Property="Background" Value="{DynamicResource DisabledBackgroundBrush}" /><Setter TargetName="Border" Property="BorderBrush" Value="{DynamicResource DisabledBorderBrush}" /><Setter Property="Foreground" Value="{DynamicResource DisabledForegroundBrush}"/></Trigger></ControlTemplate.Triggers></ControlTemplate></Setter.Value></Setter></Style><Style TargetType="controls:DrawerMenuItem"><Setter Property="HorizontalContentAlignment" Value="Stretch" /><Setter Property="Foreground" Value="{Binding RelativeSource={RelativeSource AncestorType={x:Type controls:DrawerMenu}}, Path=MenuItemForeground}"/><Setter Property="SelectionIndicatorColor" Value="{Binding RelativeSource={RelativeSource AncestorType={x:Type controls:DrawerMenu}}, Path=SelectionIndicatorColor}"/><Setter Property="Template"><Setter.Value><ControlTemplate TargetType="controls:DrawerMenuItem"><Button x:Name="PART_Button" Height="44"Command="{TemplateBinding SelectionCommand}" ToolTip="{TemplateBinding Text}"HorizontalContentAlignment="Stretch" VerticalContentAlignment="Stretch"Style="{StaticResource DrawerMenuItemButtonStyle}"><Grid><Grid.ColumnDefinitions><ColumnDefinition Width="5"/><ColumnDefinition/></Grid.ColumnDefinitions><Grid Grid.ColumnSpan="2"><Grid Width="300"><Grid.ColumnDefinitions><ColumnDefinition Width="45"/><ColumnDefinition/></Grid.ColumnDefinitions><Image Grid.Column="0" Source="{TemplateBinding Icon}" Margin="10,5,5,5"/><TextBlock Text="{TemplateBinding Text}" Grid.Column="1"Margin="10,0,0,0" HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="{StaticResource TitleFontSize}"Foreground="{TemplateBinding Foreground}"TextWrapping="Wrap"/></Grid></Grid><Grid Name="PART_ItemSelectedIndicator" Grid.Column="0" Background="{TemplateBinding SelectionIndicatorColor}" Visibility="Collapsed" /></Grid></Button><ControlTemplate.Triggers><Trigger Property="IsSelected" Value="True"><Setter TargetName="PART_ItemSelectedIndicator" Property="Visibility" Value="Visible" /></Trigger><Trigger SourceName="PART_Button" Property="IsPressed" Value="True"><Trigger.ExitActions><BeginStoryboard><Storyboard><BooleanAnimationUsingKeyFrames Storyboard.TargetProperty="IsSelected"><DiscreteBooleanKeyFrame KeyTime="00:00:00" Value="True" /></BooleanAnimationUsingKeyFrames></Storyboard></BeginStoryboard></Trigger.ExitActions></Trigger></ControlTemplate.Triggers></ControlTemplate></Setter.Value></Setter></Style><Style TargetType="controls:DrawerMenu"><Setter Property="Width" Value="50"/><Setter Property="Visibility" Value="Visible"/><Setter Property="IsOpen" Value="True"/><Setter Property="Template"><Setter.Value><ControlTemplate TargetType="controls:DrawerMenu"><Grid Background="{TemplateBinding Background}"><ToggleButton HorizontalAlignment="Left" Background="#333"VerticalAlignment="Top" Height="40" Width="50"IsChecked="{Binding RelativeSource={RelativeSource AncestorType={x:Type controls:DrawerMenu}}, Path=IsOpen}"Style="{StaticResource DrawerMenuToggleButton}"><Path HorizontalAlignment="Center" VerticalAlignment="Center" Stretch="Uniform" Width="20" Fill="{TemplateBinding MenuIconColor}"Data="{StaticResource PathMenu}"/></ToggleButton><ListBox ItemsSource="{TemplateBinding Content}" HorizontalAlignment="Left" Margin="0,40,0,0" VerticalAlignment="Top" Style="{StaticResource DrawerMenuListBox}"ScrollViewer.HorizontalScrollBarVisibility="Disabled" SelectedIndex="0"/></Grid></ControlTemplate></Setter.Value></Setter><Style.Triggers><Trigger Property="IsOpen" Value="False"><Trigger.EnterActions><BeginStoryboard><Storyboard><DoubleAnimation Storyboard.TargetProperty="Width"To="180"Duration="0:0:0.2"/></Storyboard></BeginStoryboard></Trigger.EnterActions><Trigger.ExitActions><BeginStoryboard><Storyboard><DoubleAnimation Storyboard.TargetProperty="Width"To="50"Duration="0:0:0.2"/></Storyboard></BeginStoryboard></Trigger.ExitActions></Trigger></Style.Triggers></Style>
</ResourceDictionary>

4) DrawerMenuExample.xaml 代码如下。

<UserControl x:Class="WPFDevelopers.Samples.ExampleViews.DrawerMenu.DrawerMenuExample"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:WPFDevelopers.Samples.ExampleViews.DrawerMenu"xmlns:wpfdev="https://github.com/WPFDevelopersOrg/WPFDevelopers"mc:Ignorable="d" d:DesignHeight="450" d:DesignWidth="800"><Grid Background="#FF7B7BFF"><Grid.ColumnDefinitions><ColumnDefinition  Width="Auto"/><ColumnDefinition/></Grid.ColumnDefinitions><wpfdev:DrawerMenu Background="#eee"SelectionIndicatorColor="{StaticResource PrimaryPressedSolidColorBrush}" MenuItemForeground="{StaticResource BlackSolidColorBrush}" HorizontalAlignment="Left"><wpfdev:DrawerMenu.Content><wpfdev:DrawerMenuItem Icon="pack://application:,,,/Images/CircularMenu/2.png" Text="主页"SelectionCommand="{Binding HomeCommand,RelativeSource={RelativeSource AncestorType=local:DrawerMenuExample}}"/><wpfdev:DrawerMenuItem Icon="pack://application:,,,/Images/CircularMenu/4.png" Text="Edge"SelectionCommand="{Binding EdgeCommand,RelativeSource={RelativeSource AncestorType=local:DrawerMenuExample}}"/><wpfdev:DrawerMenuItem Icon="pack://application:,,,/Images/CircularMenu/1.png" Text="云盘"SelectionCommand="{Binding CloudCommand,RelativeSource={RelativeSource AncestorType=local:DrawerMenuExample}}"/><wpfdev:DrawerMenuItem Icon="pack://application:,,,/Images/CircularMenu/8.png" Text="邮件"SelectionCommand="{Binding MailCommand,RelativeSource={RelativeSource AncestorType=local:DrawerMenuExample}}"/><wpfdev:DrawerMenuItem Icon="pack://application:,,,/Images/CircularMenu/6.png" Text="视频"SelectionCommand="{Binding VideoCommand,RelativeSource={RelativeSource AncestorType=local:DrawerMenuExample}}"/></wpfdev:DrawerMenu.Content></wpfdev:DrawerMenu><Frame Name="myFrame" Grid.Column="1" Margin="0,40,0,0"NavigationUIVisibility="Hidden"></Frame></Grid>
</UserControl>

5) DrawerMenuExample.xaml.cs 代码如下。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Input;
using System.Windows.Media;
using WPFDevelopers.Samples.Helpers;namespace WPFDevelopers.Samples.ExampleViews.DrawerMenu
{/// <summary>/// Win10MenuExample.xaml 的交互逻辑/// </summary>public partial class DrawerMenuExample : UserControl{private List<Uri> _uriList = new List<Uri>(){new Uri("ExampleViews/DrawerMenu/HomePage.xaml",UriKind.Relative),new Uri("ExampleViews/DrawerMenu/EdgePage.xaml",UriKind.Relative),};public DrawerMenuExample(){InitializeComponent();myFrame.Navigate(_uriList[0]);}public ICommand HomeCommand => new RelayCommand(obj =>{myFrame.Navigate(_uriList[0]);});public ICommand EdgeCommand => new RelayCommand(obj =>{myFrame.Navigate(_uriList[1]);});public ICommand CloudCommand => new RelayCommand(obj =>{WPFDevelopers.Minimal.Controls.MessageBox.Show("点击了云盘","提示");});public ICommand MailCommand => new RelayCommand(obj =>{WPFDevelopers.Minimal.Controls.MessageBox.Show("点击了邮件","提示");});public ICommand VideoCommand => new RelayCommand(obj =>{WPFDevelopers.Minimal.Controls.MessageBox.Show("点击了视频","提示");});}
}

6) HomePage.xaml.cs 代码如下。

<Page x:Class="WPFDevelopers.Samples.ExampleViews.DrawerMenu.HomePage"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:WPFDevelopers.Samples.ExampleViews.DrawerMenu"mc:Ignorable="d" d:DesignHeight="450" d:DesignWidth="800"Title="HomePage" Background="{StaticResource PrimaryTextSolidColorBrush}"><Grid><TextBlock VerticalAlignment="Center"HorizontalAlignment="Center"Width="400" TextAlignment="Center"TextWrapping="Wrap"Margin="0,0,0,40"FontSize="{StaticResource NormalFontSize}"><Run Foreground="White">Home</Run><Run Text="微信公众号 WPFDevelopers" FontSize="40"Foreground="#A9CC32" FontWeight="Bold"></Run><LineBreak/><Hyperlink NavigateUri="https://github.com/WPFDevelopersOrg/WPFDevelopers.git"RequestNavigate="GithubHyperlink_RequestNavigate"> Github 源代码</Hyperlink><Run/><Run/><Run/><Hyperlink NavigateUri="https://gitee.com/yanjinhua/WPFDevelopers.git"RequestNavigate="GiteeHyperlink_RequestNavigate"> 码云源代码</Hyperlink></TextBlock></Grid>
</Page>

7) EdgePage.xaml.cs 代码如下。

<Page x:Class="WPFDevelopers.Samples.ExampleViews.DrawerMenu.EdgePage"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:WPFDevelopers.Samples.ExampleViews.DrawerMenu"mc:Ignorable="d" d:DesignHeight="450" d:DesignWidth="800"Title="EdgePage"  Background="{DynamicResource PrimaryPressedSolidColorBrush}"><Grid><StackPanel VerticalAlignment="Center"Margin="0,0,0,40"><Image Source="pack://application:,,,/Images/CircularMenu/4.png" Stretch="Uniform"Width="50"/><TextBlock VerticalAlignment="Center"HorizontalAlignment="Center"TextAlignment="Center"Foreground="White"Text="即将跳转至Edge浏览器"FontSize="{StaticResource TitleFontSize}"Padding="0,10"></TextBlock></StackPanel></Grid>
</Page>

参考①[3]参考②[4]

参考资料

[1]

GitHub: https://github.com/WPFDevelopersOrg/WPFDevelopers

[2]

码云: https://github.com/WPFDevelopersOrg/WPFDevelopers

[3]

参考①: https://github.com/WPFDevelopersOrg/WPFDevelopers/tree/master/src/WPFDevelopers/Controls/DrawerMenu

[4]

参考②: https://gitee.com/WPFDevelopersOrg/WPFDevelopers/tree/master/src/WPFDevelopers/Controls/DrawerMenu

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/284650.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

selenium 定制启动 chrome 的选项

2019独角兽企业重金招聘Python工程师标准>>> selenium 定制启动 chrome 的选项 博客分类&#xff1a; java 搜索引擎&#xff0c;爬虫 使用 selenium 时&#xff0c;我们可能需要对 chrome 做一些特殊的设置&#xff0c;以完成我们期望的浏览器行为&#xff0c;比如…

平台级 SAAS 架构的基础:统一身份管理系统

业内在用户统一身份认证及授权管理领域&#xff0c;主要关注 4 个方面&#xff1a;集中账号管理&#xff08;Account&#xff09;、集中认证管理&#xff08;Authentication&#xff09;、集中授权管理&#xff08;Authorization&#xff09;和集中审计管理&#xff08;Audit&a…

【ArcGIS Pro微课1000例】0017:ArcGIS Pro 2.8制作炫酷的ETOPO1全球DEM地图

ArcGIS Pro相对于ArcGIS,在制图方面做了很大的提升,做出的地图更加优美,本文讲解基于NOAA的ETOPO1数据全球DEM数据制作炫酷的全球DEM地图,先看效果再教学! 1. 效果展示 全球 澳大利亚大陆

Js中的for in

2019独角兽企业重金招聘Python工程师标准>>> 后台数据&#xff1a; List<Map<String, Object>> uTags query.selectAllList("velocity.userGetTags", map); 前端解析&#xff1a; for(var i in data.content){//由于这里是List[i](Map).IDc…

VMWare 安装 Linux

参考 &#xff1a; http://www.aboutyun.com/thread-6780-1-1.html 这的是很详细。赞一下 我这里就简化一下。 1 下载&#xff1a; VMWare : https://download3.vmware.com/software/wkst/file/VMware-workstation-full-10.0.0-1295980.exe ubuntu : http://www.aboutyun…

【ArcGIS Pro微课1000例】0018:ArcGIS Pro 2.8通过OLE DB与个人数据库建立连接案例

对于个人数据库,Access程序可以直接打开。本文讲解在ArcGIS Pro2.8中通过OLE DB与个人数据库MDB建立联系的方法与过程。 文章目录 1. 个人数据库准备2. OLE DB连接个人数据库1. 个人数据库准备 准备一个个人数据库,在上面右键→复制文件地址。 文件地址为:"C:\test.md…

JAVA生成并导出json文件

将一个list集合转换成json文件并导出&#xff1a; 数据集合&#xff1a;    List<Object> agencyList new ArrayList<Object>();Map<String, Object> agencyMap new HashMap<>();agencyMap.put("agencyName",agencyName);agencyMap.pu…

《ASP.NET Core 6框架揭秘》实例演示[02]:基于路由、MVC和gRPC的应用开发

ASP.NET Core可以视为一种底层框架&#xff0c;它为我们构建出了基于管道的请求处理模型&#xff0c;这个管道由一个服务器和多个中间件构成&#xff0c;而与路由相关的EndpointRoutingMiddleware和EndpointMiddleware是两个最为重要的中间件。MVC和gRPC开发框架就建立在路由基…

什么是 JWT -- JSON WEB TOKEN

什么是JWT Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准&#xff08;(RFC 7519).该token被设计为紧凑且安全的&#xff0c;特别适用于分布式站点的单点登录&#xff08;SSO&#xff09;场景。JWT的声明一般被用来在身份提供者和服务提…

Re-installation failed due to different application signatures.

问题&#xff1a; 在虚拟设备上运行程序时提示安装失败。 [2010-08-08 00:38:30 - myApp] Re-installation failed due to different application signatures. [2010-08-08 00:38:30 - myApp] You must perform a full uninstall of the application. WARNING: This will remo…

【ArcGIS微课1000例】0024:ArcGIS如何连接文件夹、设认工作目录、默认地理数据库、相对路径与绝对路径?

ArcGIS软件在初次安装完成或者为了工作的方便,通常需要连接到指定的文件夹、设置默认工作路径,默认地理数据库、相对路径与绝对路径等。 文章目录 1. 文件夹连接2. 默认工作目录3. 默认地理数据库4. 相对路径与绝对路径1. 文件夹连接 在初次安装完ArcGIS时,默认没有文件夹连…

shell 用环境变量的值修改properties文件

假设有如下属性文件 demo.properties user.nametest user.password123456 ............................... 需求&#xff1a;先需要通过shell 脚本将 user.name 和 user.password 的value值替换为实际需要的用户名和密码&#xff0c; 将可以通过如下方式实现&#xff1a; sed …

【Spring Cloud】Redis缓存接入监控、运维平台CacheCloud

CacheCloud CacheCloud提供一个Redis云管理平台&#xff1a;实现多种类型(Redis Standalone、Redis Sentinel、Redis Cluster)自动部署、解决Redis实例碎片化现象、提供完善统计、监控、运维功能、减少运维成本和误操作&#xff0c;提高机器的利用率&#xff0c;提供灵活的伸缩…

[Win10应用开发] 使用 Windows 推送服务 (WNS)

前言 Windows 推送服务&#xff08;WNS&#xff09;也是 Win10 通知机制中的一种&#xff0c;今天与大家一起学习一下有关WNS的相关知识。使用 Windows 推送服务的前提是你需要有一个微软开发者账号&#xff0c;这样才能得到一些合法的密钥信息用于与WNS服务器完成通讯操作。 …

Windows 11 新版 25158 推送!全新搜索框和图标、小组件动态内容和通知标记

面向 Dev 频道的 Windows 预览体验成员&#xff0c;微软现已推送 Windows 11 预览版 Build 25158。主要变化1.微软宣布为 Windows 11 搜索引入全新视觉体验&#xff0c;由搜索框或重新设计的搜索图标呈现。目前该功能仅向部分 Windows 预览体验成员推出&#xff0c;将在未来向所…

Python之路【第一篇】:环境搭建

虚拟机安装 下载VMwareWorkstation以及centos,安装完VMwareWorkstation&#xff0c;创建一个虚拟机&#xff0c;然后在新创建的虚拟机上运行centos linux环境搭建 公司开发使用linux的原因&#xff1a;稳定、安全、开源 在虚拟机中使用centos这个版本&#xff0c;作为服务器端的…

【BIM入门实战】Revit创建地形的几种方法及优缺点

Revit在体量和场地选项卡的【地形表面】工具可以创建三维地形,有三种方法:放置点、指定点文件和导入实例文件、倾斜摄影点云技术和InfraWorks地形生成。 文章目录 1. 放置点2. 指定点文件3. 导入实例文件4. 倾斜摄影点云技术5. InfraWorks地形生成1. 放置点 放置点功能位于体…

2024年起重机司机(限门式起重机)证考试题库及起重机司机(限门式起重机)试题解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年起重机司机(限门式起重机)证考试题库及起重机司机(限门式起重机)试题解析是安全生产模拟考试一点通结合&#xff08;安监局&#xff09;特种作业人员操作证考试大纲和&#xff08;质检局&#xff09;特种设备作…

微服务架构下的统一身份认证和授权

一、预备知识 本文讨论基于微服务架构下的身份认证和用户授权的技术方案&#xff0c;在阅读之前&#xff0c;最好先熟悉并理解以下几个知识点&#xff1a; 微服务架构相关概念&#xff1a;服务注册、服务发现、API 网关身份认证和用户授权&#xff1a;SSO、CAS、OAuth2.0、JW…

使用vh来制作高度自适应页面和元素垂直居中

为什么80%的码农都做不了架构师&#xff1f;>>> vh单位 vh是CSS3中的一个长度单位&#xff0c;其值为&#xff1a;100vh 视窗高度。即如果窗口高度为500px&#xff0c;那么 1vh 5px。具体的值会随着浏览器视窗高度的改变而实时改变&#xff0c;因此可以利用这个单…