设置Excel文档的ADRMS权限的工具类

设置Excel文档权限的工具类

 

引用Microsoft Office 12.0 Object Library

引用Microsoft Excel 12.0 Object Library

 

 

///   <summary>
    
///  设置Excel文档权限的工具类
    
///   </summary>
     public   class  RmsExcelHelper : IDisposable
    {
        
///   <summary>
        
///  Excel应用程序对象
        
///   </summary>
         private  Microsoft.Office.Interop.Excel.ApplicationClass app;

        
///   <summary>
        
///  Excel文档路径
        
///   </summary>
         private   string  filePath;
        
public   string  FilePath
        {
            
get  {  return   this .filePath; }
            
set  {  this .filePath  =  value; }
        }

        
///   <summary>
        
///  权限集合
        
///   </summary>
         private  List < RmsExcelPermission >  rmsPerms  =   new  List < RmsExcelPermission > ();
        
public  List < RmsExcelPermission >  RmsPerms
        {
            
get  {  return   this .rmsPerms; }
        }

        
///   <summary>
        
///  空值
        
///   </summary>
         private   object  MISSINGVALUE  =  System.Reflection.Missing.Value;

        
///   <summary>
        
///  错误消息
        
///   </summary>
         public   string  ErrMessage  =   string .Empty;

        
        
///   <summary>
        
///  是否xlsx文档
        
///   </summary>
         private   bool  is2007()
        {
            
bool  result  =   false ;

            result 
=  System.IO.Path.GetExtension( this .filePath).ToLower()  ==   " xlsx " ;

            
return  result;
        }

        
///   <summary>
        
///  Rms授权后的文件名
        
///   </summary>
         private   string  GetRmsFileName()
        {
            
string  filename  =   string .Empty;

            filename 
=  System.IO.Path.Combine(System.IO.Path.GetDirectoryName( this .filePath), System.IO.Path.GetFileNameWithoutExtension( this .filePath)  +   " _RMS "   +  System.IO.Path.GetExtension( this .filePath));

            
return  filename;
        }

        
///   <summary>
        
///  保存
        
///   </summary>
         public   bool  Save()
        {
            
// 清除错误消息
             this .ErrMessage  =   string .Empty;

            
bool  result  =   false ;

            
string  filename_src  =   this .filePath;
            
string  filename_dst  =   this .GetRmsFileName();

            
try
            {
                
if  ( this .app  ==   null )
                {
                    
this .app  =   new  Microsoft.Office.Interop.Excel.ApplicationClass();
                }

                var doc 
=   this .app.Workbooks.Open(filename_src, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
                                                     MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
                                                     MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
                                                     MISSINGVALUE, MISSINGVALUE, MISSINGVALUE);

                
try
                {
                    doc.Activate();

                    doc.Permission.Enabled 
=   true ;

                    
foreach  (var permission  in   this .rmsPerms)
                    {
                        doc.Permission.Add(permission.UserId, permission.Perms, MISSINGVALUE);
                    }

                    doc.SaveAs(filename_dst, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
                               MISSINGVALUE, MISSINGVALUE, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange,
                               MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE);

                    result 
=   true ;

                }
                
finally
                {
                    doc.Close(MISSINGVALUE, MISSINGVALUE, MISSINGVALUE);
                }
            }
            
catch  (Exception ex)
            {
                
this .ErrMessage  =  ex.Message;
            }

            
return  result;
            
        }

        
///   <summary>
        
///  退出Excel应用程序
        
///   </summary>
         public   void  Dispose()
        {
            
if  ( this .app  !=   null )
            {
                
this .app.Quit();
                
this .app  =   null ;
            }
        }
    }

    
public   class  RmsExcelPermission
    {
        
public   string  UserId;
        
public  Microsoft.Office.Core.MsoPermission Perms;
    }

 

使用示例

 

using  (RmsExcelHelper helper  =   new  RmsExcelHelper())
{
    helper.FilePath 
=  filePath;
    helper.RmsPerms.Add(
new  RmsExcelPermission() { UserId = " Everyone " , Perms =  Microsoft.Office.Core.MsoPermission.msoPermissionRead });

    
if  (helper.Save())
    {
        MessageBox.Show(
" ok " );
    }
    
else
    {
        MessageBox.Show(helper.ErrMessage);
    }
}

 

转载于:https://www.cnblogs.com/wangyz/archive/2011/08/29/2157194.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值