バージョン選択

フォーラム

メニュー

オンライン状況

43 人のユーザが現在オンラインです。 (38 人のユーザが フォーラム を参照しています。)
登録ユーザ: 0
ゲスト: 43
もっと...

サイト内検索

質問 > フロント機能 > 仮会員を無効にしていても、仮会員として登録されてしまう

フロント機能

新規スレッドを追加する

フラット表示 前のトピック | 次のトピック
投稿者 スレッド
h_tanaka
投稿日時: 2019/2/20 15:44
対応状況: −−−
登録日: 2016/7/22
居住地: 愛媛県
投稿: 1646
Re: 仮会員を無効にしていても、仮会員として登録されてしまう
本件、おそらく解決しました。

src/Eccube/Controller/EntryController.php
activate() 内、flush() の直後にトランザクションをcommitするようにしたところ、現象が起こらなくなりました。
(下記のソース内で★の処理を追加)

おそらくどこかでトランザクションが開始されたままcommitもrollbackもされず、DBに保存されなかったのだと思われます。
ただ、トランザクションを開始にしっぱなしにしているような怪しいソースはどこにも見当たらず、ログにもエラー等は出力されていなかったです。
また、再現条件も不明なままのため、確実に解決したかどうかはわかりません。

    /**
     * 会員のアクティベート(本会員化)を行う.
     *
     * @param Application $app
     * @param Request $request
     * @param $secret_key
     * @return \Symfony\Component\HttpFoundation\Response
     */
    public function activate(Application $app, Request $request, $secret_key)
    {
        $errors = $app['validator']->validateValue($secret_key, array(
                new Assert\NotBlank(),
                new Assert\Regex(array(
                    'pattern' => '/^[a-zA-Z0-9]+$/',
                ))
            )
        );

        if ($request->getMethod() === 'GET' && count($errors) === 0) {
            log_info('本会員登録開始');

            try {
                $Customer = $app['eccube.repository.customer']
                    ->getNonActiveCustomerBySecretKey($secret_key);
            } catch (\Exception $e) {
                throw new HttpException\NotFoundHttpException('※ 既に会員登録が完了しているか、無効なURLです。');
            }

            $CustomerStatus = $app['eccube.repository.customer_status']->find(CustomerStatus::ACTIVE);
            $Customer->setStatus($CustomerStatus);
            $app['orm.em']->persist($Customer);
            $app['orm.em']->flush();

            $app['orm.em']->getConnection()->commit();  // ★ 追加

            log_info('本会員登録完了');

            $event = new EventArgs(
                array(
                    'Customer' => $Customer,
                ),
                $request
            );
            $app['eccube.event.dispatcher']->dispatch(EccubeEvents::FRONT_ENTRY_ACTIVATE_COMPLETE, $event);

            // メール送信
            $app['eccube.service.mail']->sendCustomerCompleteMail($Customer);

            // 本会員登録してログイン状態にする
            $token = new UsernamePasswordToken($Customer, null, 'customer', array('ROLE_USER'));
            $this->getSecurity($app)->setToken($token);
            $request->getSession()->migrate(true, $app['config']['cookie_lifetime']);

            log_info('ログイン済に変更', array($app->user()->getId()));

            return $app->render('Entry/activate.twig');
        } else {
            throw new HttpException\AccessDeniedHttpException('不正なアクセスです。');
        }
    }


----------------
EC-CUBE 《プラチナ》ランクパートナー
トエビス株式会社 田中 宏典
EC-CUBEの機能やデザインのカスタマイズ承ります。

フラット表示 前のトピック | 次のトピック


題名 投稿者 日時
   仮会員を無効にしていても、仮会員として登録されてしまう nakamori 2019/1/11 13:09
     Re: 仮会員を無効にしていても、仮会員として登録されてしまう 468 2019/1/11 23:25
     Re: 仮会員を無効にしていても、仮会員として登録されてしまう h_tanaka 2019/2/18 17:32
       Re: 仮会員を無効にしていても、仮会員として登録されてしまう h_tanaka 2019/2/20 11:33
       » Re: 仮会員を無効にしていても、仮会員として登録されてしまう h_tanaka 2019/2/20 15:44

 



ログイン


EC-CUBE公式 Amazon Payプラグイン

統計情報

総メンバー数は88,880名です
総投稿数は110,000件です

投稿数ランキング

1
seasoft
7367
2
468
3217
3
AMUAMU
2712
4
nanasess
2313
5
umebius
2085
6
yuh
1819
7
h_tanaka
1646
8
red
1570
9
mcontact
1295
10
tsuji
958
11
fukap
907
12
shutta
835
13
tao_s
799
14 ramrun 789
15 karin 689
16 sumida 641
17
homan
633
18 DELIGHT 572
19
patapata
502
20
flealog
485


ネットショップの壺

EC-CUBEインテグレートパートナー

Copyright© EC-CUBE CO.,LTD. All Rights Reserved.