设为首页 收藏本站
查看: 1245|回复: 0

[经验分享] .NET连接SAP系统专题:C#调用BAPI给账户赋予权限(八)

[复制链接]

尚未签到

发表于 2015-9-17 10:20:47 | 显示全部楼层 |阅读模式
  接上篇博文。
  上篇博文讲到C#调用BAPI BAPI_USER_CREATE 来生成SAP账户,但是新建的账户一点权限也没有,现在我们就再次利用BAPI给账户授予权限。
  首先,我们在BAPI画面里查找出相关的BAPI出来,利用角色去给用户添加权限:
DSC0000.jpg
  双击此BAPI,进入到BAPI预览画面:
DSC0001.jpg
  Table属性页:
DSC0002.jpg
  第一个ACTIVITYGROUPS是指我们要传进去的表格内容,不再是一个栏位和结构内容了。第二个的RETURN则是返回调用结果。
  双击BAPIAGR的结构,进入结构详情画面:
DSC0003.jpg
  以上AGR_NAME是角色名,应该是必须要的。
  那么,接下去就是在C#中编写相应的代码来调用它了。
  1、首先引用dll,然后在程序开头:using SAP.Middleware.Connector;
  2、接下去就是设置登陆参数了,以前相关博文都有说明:
  public class MyBackendConfig : IDestinationConfiguration
  {
  public RfcConfigParameters GetParameters(String destinationName)
  {
  if ("PRD_000".Equals(destinationName))
  {
  RfcConfigParameters parms = new RfcConfigParameters();
  parms.Add(RfcConfigParameters.AppServerHost, "192.168.1.3");
  parms.Add(RfcConfigParameters.SystemNumber, "00");
  parms.Add(RfcConfigParameters.User, "MENGXIN");
  parms.Add(RfcConfigParameters.Password, "5239898");
  parms.Add(RfcConfigParameters.Client, "888");
  parms.Add(RfcConfigParameters.Language, "ZH");
  parms.Add(RfcConfigParameters.PoolSize, "5");
  parms.Add(RfcConfigParameters.MaxPoolSize, "10");
  parms.Add(RfcConfigParameters.IdleTimeout, "60");
  return parms;
  }
  else return null;
  }
  public bool ChangeEventsSupported()
  {
  return false;
  }
  public event RfcDestinationManager.ConfigurationChangeHandler ConfigurationChanged;
  }
  3、设置一个方法,引用这个登陆参数的类:
  public void nco()
  {
  IDestinationConfiguration ID = new MyBackendConfig();
  RfcDestinationManager.RegisterDestinationConfiguration(ID);
  RfcDestination prd = RfcDestinationManager.GetDestination("PRD_000");
  RfcDestinationManager.UnregisterDestinationConfiguration(ID);
  nco(prd);
  }
  4、然后就是开始了调用代码,以下代码全部放出,然后一行一行说明:
  public void nco(RfcDestination prd)
  {
  //调用BAPI
  RfcFunctionMetadata BAPI_COMPANYCODE_GETDETAIL_MD = prd.Repository.GetFunctionMetadata("BAPI_USER_ACTGROUPS_ASSIGN");
  IRfcFunction function = null;
  function = BAPI_COMPANYCODE_GETDETAIL_MD.CreateFunction();
  //传入我们要赋予权限的用户名
  function.SetValue("USERNAME", USERID.Text.Trim());
  //接下去就是传入角色名。由于ACTIVITYGROUPS 是在Table属性页,所以我们是用Table 而不是Import和Export属性页里面用的Structure
  IRfcTable ROFTable = function.GetTable("ACTIVITYGROUPS");
  //上面语句产生的ROFTable 其实是一张空表,里面除了有那几个栏位之外是没有任何记录的,所以在对表格赋值之前需要先进性新增一行
  ROFTable .Insert();
  //接下去就是对表格当前行的相关栏位赋值。如下的角色名“MIS”是预选在SAP中建立好的
  ROFTable .CurrentRow.SetValue("AGR_NAME", "MIS");
  ROFTable .CurrentRow.SetValue("FROM_DAT", "20110825");
  ROFTable .CurrentRow.SetValue("TO_DAT", "99991231");
  //传入该赋值后的表格
  function.SetValue("ACTIVITYGROUPS", ROFTable);
  //引用回传结果
  IRfcTable RETURNStructure = function.GetTable("RETURN");
  //提交调用         
  function.Invoke(prd);
  //显示调用结果
  MessageBox.Show(RETURNStructure.GetString("MESSAGE").ToString());
  prd = null;
  }
  5、调用结果如下:
DSC0004.jpg
DSC0005.jpg
DSC0006.jpg
  如此则此用户已经赋予相应的权限了,运行所有T-CODE,没问题!
  对了,如果要赋予多个角色的话,那么就是多做ROFTable.Insert();然后再做相应赋值即可。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-114836-1-1.html 上篇帖子: SAP校园招聘笔试 下篇帖子: .NET连接SAP系统专题:C#(NCO3)调用BAPI的代码(七)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表